mirror of
https://github.com/nlohmann/json.git
synced 2025-08-09 05:22:48 +03:00
1.6 KiB
1.6 KiB
nlohmann::basic_json::unflatten
basic_json unflatten() const;
The function restores the arbitrary nesting of a JSON value that has been flattened before using the
flatten()
function. The JSON value must meet certain constraints:
- The value must be an object.
- The keys must be JSON pointers (see RFC 6901)
- The mapped values must be primitive JSON types.
Return value
the original JSON from a flattened version
Exception safety
Strong exception safety: if an exception occurs, the original value stays intact.
Exceptions
The function can throw the following exceptions:
- Throws
type_error.314
if value is not an object - Throws
type_error.315
if object values are not primitive
Complexity
Linear in the size of the JSON value.
Notes
Empty objects and arrays are flattened by flatten()
to #!json null
values and cannot unflattened to
their original type. Apart from this example, for a JSON value j
, the following is always true:
#!cpp j == j.flatten().unflatten()
.
Examples
??? example
The following code shows how a flattened JSON object is unflattened into the original nested JSON object.
```cpp
--8<-- "examples/unflatten.cpp"
```
Output:
```json
--8<-- "examples/unflatten.output"
```
See also
- flatten the reverse function
Version history
- Added in version 2.0.0.