63 lines
1.8 KiB
Markdown
63 lines
1.8 KiB
Markdown
|
|
# operator<<(basic_json)
|
||
|
|
|
||
|
|
```cpp
|
||
|
|
std::ostream& operator<<(std::ostream& o, const basic_json& j);
|
||
|
|
```
|
||
|
|
|
||
|
|
Serialize the given JSON value `j` to the output stream `o`. The JSON value will be serialized using the
|
||
|
|
[`dump`](dump.md) member function.
|
||
|
|
|
||
|
|
- The indentation of the output can be controlled with the member variable `width` of the output stream `o`. For
|
||
|
|
instance, using the manipulator `std::setw(4)` on `o` sets the indentation level to `4` and the serialization result
|
||
|
|
is the same as calling `dump(4)`.
|
||
|
|
- The indentation character can be controlled with the member variable `fill` of the output stream `o`. For instance,
|
||
|
|
the manipulator `std::setfill('\\t')` sets indentation to use a tab character rather than the default space character.
|
||
|
|
|
||
|
|
## Parameters
|
||
|
|
|
||
|
|
`o` (in, out)
|
||
|
|
: stream to serialize to
|
||
|
|
|
||
|
|
`j` (in)
|
||
|
|
: JSON value to serialize
|
||
|
|
|
||
|
|
## Return value
|
||
|
|
|
||
|
|
the stream `o`
|
||
|
|
|
||
|
|
## Exceptions
|
||
|
|
|
||
|
|
Throws [`type_error.316`](../../home/exceptions.md#jsonexceptiontype_error316) if a string stored inside the JSON value
|
||
|
|
is not UTF-8 encoded. Note that unlike the [`dump`](dump.md) member functions, no `error_handler` can be set.
|
||
|
|
|
||
|
|
## Complexity
|
||
|
|
|
||
|
|
Linear.
|
||
|
|
|
||
|
|
## Examples
|
||
|
|
|
||
|
|
??? example
|
||
|
|
|
||
|
|
The example below shows the serialization with different parameters to `width` to adjust the indentation level.
|
||
|
|
|
||
|
|
```cpp
|
||
|
|
--8<-- "examples/operator_serialize.cpp"
|
||
|
|
```
|
||
|
|
|
||
|
|
Output:
|
||
|
|
|
||
|
|
```json
|
||
|
|
--8<-- "examples/operator_serialize.output"
|
||
|
|
```
|
||
|
|
|
||
|
|
## Version history
|
||
|
|
|
||
|
|
- Added in version 1.0.0
|
||
|
|
- Support for indentation character added in version 3.0.0.
|
||
|
|
|
||
|
|
!!! warning "Deprecation"
|
||
|
|
|
||
|
|
This function replaces function `#!cpp std::ostream& operator>>(const basic_json& j, std::ostream& o)` which has
|
||
|
|
been deprecated in version 3.0.0. It will be removed in version 4.0.0. Please replace calls like `#!cpp j >> o;`
|
||
|
|
with `#!cpp o << j;`.
|