JSON writer. More...
#include <fwd.h>
Classes | |
struct | Level |
Information for each nested level. More... | |
Public Types | |
typedef SourceEncoding::Ch | Ch |
Public Member Functions | |
Writer (OutputStream &os, StackAllocator *stackAllocator=0, size_t levelDepth=kDefaultLevelDepth) | |
Constructor. More... | |
Writer (StackAllocator *allocator=0, size_t levelDepth=kDefaultLevelDepth) | |
void | Reset (OutputStream &os) |
Reset the writer with a new stream. More... | |
bool | IsComplete () const |
Checks whether the output is a complete JSON. More... | |
int | GetMaxDecimalPlaces () const |
void | SetMaxDecimalPlaces (int maxDecimalPlaces) |
Sets the maximum number of decimal places for double output. More... | |
bool | RawValue (const Ch *json, size_t length, Type type) |
Write a raw JSON value. More... | |
void | Flush () |
Flush the output stream. More... | |
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) |
Writes the given double value to the stream. More... | |
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) |
Convenience extensions | |
bool | String (const Ch *const &str) |
Simpler but slower overload. More... | |
bool | Key (const Ch *const &str) |
Static Public Attributes | |
static const int | kDefaultMaxDecimalPlaces = 324 |
Protected Member Functions | |
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) |
template<> | |
bool | WriteInt (int i) |
template<> | |
bool | WriteUint (unsigned u) |
template<> | |
bool | WriteInt64 (int64_t i64) |
template<> | |
bool | WriteUint64 (uint64_t u) |
template<> | |
bool | WriteDouble (double d) |
Protected Attributes | |
OutputStream * | os_ |
internal::Stack< StackAllocator > | level_stack_ |
int | maxDecimalPlaces_ |
bool | hasRoot_ |
Static Protected Attributes | |
static const size_t | kDefaultLevelDepth = 32 |
Private Member Functions | |
Writer (const Writer &) | |
Writer & | operator= (const Writer &) |
JSON writer.
Writer implements the concept Handler. It generates JSON text by events to an output os.
User may programmatically calls the functions of a writer to generate JSON text.
On the other side, a writer can also be passed to objects that generates events,
for example Reader::Parse() and Document::Accept().
OutputStream | Type of output stream. |
SourceEncoding | Encoding of source string. |
TargetEncoding | Encoding of output stream. |
StackAllocator | Type of allocator for allocating memory of stack. |
|
inlineexplicit |
Constructor.
os | Output stream. |
stackAllocator | User supplied allocator. If it is null, it will create a private one. |
levelDepth | Initial capacity of stack. |
Definition at line 101 of file writer.h.
|
inlineexplicit |
Definition at line 105 of file writer.h.
|
private |
|
inline |
|
inline |
|
inline |
|
inline |
Definition at line 230 of file writer.h.
|
inlineprotected |
Definition at line 494 of file writer.h.
|
inline |
Flush the output stream.
Allows the user to flush the output stream immediately.
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
Definition at line 259 of file writer.h.
|
inline |
|
private |
|
inlineprotected |
Definition at line 473 of file writer.h.
|
inline |
|
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. |
Definition at line 271 of file writer.h.
|
inline |
Reset the writer with a new stream.
This function reset the writer with a new stream and default settings, in order to make a Writer object reusable for output multiple JSONs.
os | New output stream. Writer<OutputStream> writer(os1); writer.StartObject(); // ... writer.EndObject(); writer.Reset(os2); writer.StartObject(); // ... writer.EndObject(); |
Definition at line 133 of file writer.h.
|
inlineprotected |
Definition at line 450 of file writer.h.
|
inline |
Sets the maximum number of decimal places for double output.
This setting truncates the output with specified number of decimal places.
For example,
The default setting does not truncate any decimal places. You can restore to this setting by calling
Definition at line 172 of file writer.h.
|
inline |
|
inline |
|
inline |
|
inline |
Simpler but slower overload.
Definition at line 258 of file writer.h.
|
inline |
|
inline |
|
inlineprotected |
Definition at line 300 of file writer.h.
|
inlineprotected |
Definition at line 348 of file writer.h.
|
inlineprotected |
Definition at line 546 of file writer.h.
|
inlineprotected |
|
inlineprotected |
|
inlineprotected |
Definition at line 312 of file writer.h.
|
inlineprotected |
Definition at line 514 of file writer.h.
|
inlineprotected |
Definition at line 330 of file writer.h.
|
inlineprotected |
Definition at line 530 of file writer.h.
|
inlineprotected |
Definition at line 295 of file writer.h.
|
inlineprotected |
Definition at line 459 of file writer.h.
|
inlineprotected |
|
inlineprotected |
|
inlineprotected |
Definition at line 376 of file writer.h.
|
inlineprotected |
Definition at line 321 of file writer.h.
|
inlineprotected |
Definition at line 522 of file writer.h.
|
inlineprotected |
Definition at line 339 of file writer.h.
|
inlineprotected |
Definition at line 538 of file writer.h.
|
staticprotected |
|
static |
|
protected |
|
protected |
|
protected |