Writer with indentation and spacing. More...
#include <prettywriter.h>
Public Types | |
| typedef Writer< OutputStream, SourceEncoding, TargetEncoding, StackAllocator, writeFlags > | Base |
| typedef Base::Ch | Ch |
Public Types inherited from rapidjson::Writer< OutputStream, SourceEncoding, TargetEncoding, StackAllocator, writeFlags > | |
| typedef SourceEncoding::Ch | Ch |
Public Member Functions | |
| PrettyWriter (OutputStream &os, StackAllocator *allocator=0, size_t levelDepth=Base::kDefaultLevelDepth) | |
| Constructor. | |
| PrettyWriter (StackAllocator *allocator=0, size_t levelDepth=Base::kDefaultLevelDepth) | |
| PrettyWriter & | SetIndent (Ch indentChar, unsigned indentCharCount) |
| Set custom indentation. | |
| PrettyWriter & | SetFormatOptions (PrettyFormatOptions options) |
| Set pretty writer formatting options. | |
Implementation of Handler | |
| |
| bool | Null () |
| bool | Bool (bool b) |
| bool | Int (int i) |
| bool | Uint (unsigned u) |
| bool | Int64 (int64_t i64) |
| bool | Uint64 (uint64_t u64) |
| bool | Double (double d) |
| bool | RawNumber (const Ch *str, SizeType length, bool copy=false) |
| bool | String (const Ch *str, SizeType length, bool copy=false) |
| bool | StartObject () |
| bool | Key (const Ch *str, SizeType length, bool copy=false) |
| bool | EndObject (SizeType memberCount=0) |
| bool | StartArray () |
| bool | EndArray (SizeType memberCount=0) |
Public Member Functions inherited from rapidjson::Writer< OutputStream, SourceEncoding, TargetEncoding, StackAllocator, writeFlags > | |
| Writer (OutputStream &os, StackAllocator *stackAllocator=0, size_t levelDepth=kDefaultLevelDepth) | |
| Constructor. | |
| Writer (StackAllocator *allocator=0, size_t levelDepth=kDefaultLevelDepth) | |
| void | Reset (OutputStream &os) |
| Reset the writer with a new stream. | |
| bool | IsComplete () const |
| Checks whether the output is a complete JSON. | |
| int | GetMaxDecimalPlaces () const |
| void | SetMaxDecimalPlaces (int maxDecimalPlaces) |
| Sets the maximum number of decimal places for double output. | |
| bool | Null () |
| bool | Bool (bool b) |
| bool | Int (int i) |
| bool | Uint (unsigned u) |
| bool | Int64 (int64_t i64) |
| bool | Uint64 (uint64_t u64) |
| bool | Double (double d) |
Writes the given double value to the stream. | |
| bool | RawNumber (const Ch *str, SizeType length, bool copy=false) |
| bool | String (const Ch *str, SizeType length, bool copy=false) |
| bool | StartObject () |
| bool | Key (const Ch *str, SizeType length, bool copy=false) |
| bool | EndObject (SizeType memberCount=0) |
| bool | StartArray () |
| bool | EndArray (SizeType elementCount=0) |
| bool | String (const Ch *str) |
| Simpler but slower overload. | |
| bool | Key (const Ch *str) |
| bool | RawValue (const Ch *json, size_t length, Type type) |
| Write a raw JSON value. | |
Convenience extensions | |
| Ch | indentChar_ |
| unsigned | indentCharCount_ |
| PrettyFormatOptions | formatOptions_ |
| bool | String (const Ch *str) |
| Simpler but slower overload. | |
| bool | Key (const Ch *str) |
| bool | RawValue (const Ch *json, size_t length, Type type) |
| Write a raw JSON value. | |
| void | PrettyPrefix (Type type) |
| void | WriteIndent () |
Additional Inherited Members | |
Static Public Attributes inherited from rapidjson::Writer< OutputStream, SourceEncoding, TargetEncoding, StackAllocator, writeFlags > | |
| static const int | kDefaultMaxDecimalPlaces = 324 |
| static const size_t | kDefaultLevelDepth = 32 |
Protected Member Functions inherited from rapidjson::Writer< OutputStream, SourceEncoding, TargetEncoding, StackAllocator, writeFlags > | |
| bool | WriteInt (int i) |
| bool | WriteUint (unsigned u) |
| bool | WriteInt64 (int64_t i64) |
| bool | WriteUint64 (uint64_t u) |
| bool | WriteDouble (double d) |
| bool | WriteNull () |
| bool | WriteBool (bool b) |
| bool | WriteInt (int i) |
| bool | WriteUint (unsigned u) |
| bool | WriteInt64 (int64_t i64) |
| bool | WriteUint64 (uint64_t u64) |
| bool | WriteDouble (double d) |
| bool | WriteString (const Ch *str, SizeType length) |
| bool | ScanWriteUnescapedString (GenericStringStream< SourceEncoding > &is, size_t length) |
| bool | WriteStartObject () |
| bool | WriteEndObject () |
| bool | WriteStartArray () |
| bool | WriteEndArray () |
| bool | WriteRawValue (const Ch *json, size_t length) |
| void | Prefix (Type type) |
| bool | EndValue (bool ret) |
Protected Attributes inherited from rapidjson::Writer< OutputStream, SourceEncoding, TargetEncoding, StackAllocator, writeFlags > | |
| OutputStream * | os_ |
| internal::Stack< StackAllocator > | level_stack_ |
| int | maxDecimalPlaces_ |
| bool | hasRoot_ |
Writer with indentation and spacing.
|
inlineexplicit |
Constructor.
| os | Output stream. |
| allocator | User supplied allocator. If it is null, it will create a private one. |
| levelDepth | Initial capacity of stack. |
|
inline |
Write a raw JSON value.
For user to write a stringified JSON as a value.
| json | A well-formed JSON value. It should not contain null character within [0, length - 1] range. |
| length | Length of the json. |
| type | Type of the root of json. |
|
inline |
Set pretty writer formatting options.
| options | Formatting options. |
|
inline |
Set custom indentation.
| indentChar | Character for indentation. Must be whitespace character (' ', '\t', '\n', '\r'). |
| indentCharCount | Number of indent characters for each indentation level. |