forked from Research/WhisperCom
Dominik Meyer
cc002ebfbb
git-subtree-dir: libs/json git-subtree-split: f42a74b8f53cc308647123d49d33d1c8122e3f42
57 lines
1.5 KiB
Markdown
57 lines
1.5 KiB
Markdown
# basic_json::emplace
|
|
|
|
```cpp
|
|
template<class... Args>
|
|
std::pair<iterator, bool> emplace(Args&& ... args);
|
|
```
|
|
|
|
Inserts a new element into a JSON object constructed in-place with the given `args` if there is no element with the key
|
|
in the container. If the function is called on a JSON null value, an empty object is created before appending the value
|
|
created from `args`.
|
|
|
|
## Template parameters
|
|
|
|
`Args`
|
|
: compatible types to create a `basic_json` object
|
|
|
|
## Parameters
|
|
|
|
`args` (in)
|
|
: arguments to forward to a constructor of `basic_json`
|
|
|
|
## Return value
|
|
|
|
a pair consisting of an iterator to the inserted element, or the already-existing element if no insertion happened, and
|
|
a `#!cpp bool` denoting whether the insertion took place.
|
|
|
|
## Exceptions
|
|
|
|
Throws [`type_error.311`](../../home/exceptions.md#jsonexceptiontype_error311) when called on a type other than JSON
|
|
object or `#!json null`; example: `"cannot use emplace() with number"`
|
|
|
|
## Complexity
|
|
|
|
Logarithmic in the size of the container, O(log(`size()`)).
|
|
|
|
## Examples
|
|
|
|
??? example
|
|
|
|
The example shows how `emplace()` can be used to add elements to a JSON object. Note how the `#!json null` value was
|
|
silently converted to a JSON object. Further note how no value is added if there was already one value stored with
|
|
the same key.
|
|
|
|
```cpp
|
|
--8<-- "examples/emplace.cpp"
|
|
```
|
|
|
|
Output:
|
|
|
|
```json
|
|
--8<-- "examples/emplace.output"
|
|
```
|
|
|
|
## Version history
|
|
|
|
- Since version 2.0.8.
|