|
| GenericReader (StackAllocator *stackAllocator=0, size_t stackCapacity=kDefaultStackCapacity) |
| Constructor. More...
|
|
size_t | GetErrorOffset () const |
| Get the position of last parsing error in input, 0 otherwise. More...
|
|
ParseErrorCode | GetParseErrorCode () const |
| Get the ParseErrorCode of last parsing. More...
|
|
bool | HasParseError () const |
| Whether a parse error has occurred in the last parsing. More...
|
|
RAPIDJSON_FORCEINLINE bool | IterativeParseComplete () const |
| Check if token-by-token parsing JSON text is complete. More...
|
|
void | IterativeParseInit () |
| Initialize JSON text token-by-token parsing. More...
|
|
template<unsigned parseFlags, typename InputStream , typename Handler > |
bool | IterativeParseNext (InputStream &is, Handler &handler) |
| Parse one token from JSON text. More...
|
|
template<unsigned parseFlags, typename InputStream , typename Handler > |
ParseResult | Parse (InputStream &is, Handler &handler) |
| Parse JSON text. More...
|
|
template<typename InputStream , typename Handler > |
ParseResult | Parse (InputStream &is, Handler &handler) |
| Parse JSON text (with kParseDefaultFlags) More...
|
|
|
void | ClearStack () |
|
| GenericReader (const GenericReader &) |
|
template<typename InputStream > |
void | HandleError (IterativeParsingState src, InputStream &is) |
|
RAPIDJSON_FORCEINLINE bool | IsIterativeParsingCompleteState (IterativeParsingState s) const |
|
RAPIDJSON_FORCEINLINE bool | IsIterativeParsingDelimiterState (IterativeParsingState s) const |
|
template<unsigned parseFlags, typename InputStream , typename Handler > |
ParseResult | IterativeParse (InputStream &is, Handler &handler) |
|
GenericReader & | operator= (const GenericReader &) |
|
template<unsigned parseFlags, typename InputStream , typename Handler > |
void | ParseArray (InputStream &is, Handler &handler) |
|
template<unsigned parseFlags, typename InputStream , typename Handler > |
void | ParseFalse (InputStream &is, Handler &handler) |
|
template<typename InputStream > |
unsigned | ParseHex4 (InputStream &is, size_t escapeOffset) |
|
template<unsigned parseFlags, typename InputStream , typename Handler > |
void | ParseNull (InputStream &is, Handler &handler) |
|
template<unsigned parseFlags, typename InputStream , typename Handler > |
void | ParseNumber (InputStream &is, Handler &handler) |
|
template<unsigned parseFlags, typename InputStream , typename Handler > |
void | ParseObject (InputStream &is, Handler &handler) |
|
template<unsigned parseFlags, typename InputStream , typename Handler > |
void | ParseString (InputStream &is, Handler &handler, bool isKey=false) |
|
template<unsigned parseFlags, typename SEncoding , typename TEncoding , typename InputStream , typename OutputStream > |
RAPIDJSON_FORCEINLINE void | ParseStringToStream (InputStream &is, OutputStream &os) |
|
template<unsigned parseFlags, typename InputStream , typename Handler > |
void | ParseTrue (InputStream &is, Handler &handler) |
|
template<unsigned parseFlags, typename InputStream , typename Handler > |
void | ParseValue (InputStream &is, Handler &handler) |
|
RAPIDJSON_FORCEINLINE IterativeParsingState | Predict (IterativeParsingState state, Token token) const |
|
template<unsigned parseFlags, typename InputStream > |
void | SkipWhitespaceAndComments (InputStream &is) |
|
RAPIDJSON_FORCEINLINE Token | Tokenize (Ch c) const |
|
template<unsigned parseFlags, typename InputStream , typename Handler > |
RAPIDJSON_FORCEINLINE IterativeParsingState | Transit (IterativeParsingState src, Token token, IterativeParsingState dst, InputStream &is, Handler &handler) |
|
template<typename SourceEncoding, typename TargetEncoding, typename StackAllocator = CrtAllocator>
class GenericReader< SourceEncoding, TargetEncoding, StackAllocator >
SAX-style JSON parser. Use Reader for UTF8 encoding and default allocator.
GenericReader parses JSON text from a stream, and send events synchronously to an object implementing Handler concept.
It needs to allocate a stack for storing a single decoded string during non-destructive parsing.
For in-situ parsing, the decoded string is directly written to the source text string, no temporary buffer is required.
A GenericReader object can be reused for parsing multiple JSON text.
- Template Parameters
-
SourceEncoding | Encoding of the input stream. |
TargetEncoding | Encoding of the parse output. |
StackAllocator | Allocator type for stack. |
Definition at line 102 of file fwd.h.
template<typename SourceEncoding, typename TargetEncoding, typename StackAllocator = CrtAllocator>
template<unsigned parseFlags, typename InputStream , typename Handler >
bool GenericReader< SourceEncoding, TargetEncoding, StackAllocator >::IterativeParseNext |
( |
InputStream & |
is, |
|
|
Handler & |
handler |
|
) |
| |
|
inline |
Parse one token from JSON text.
- Template Parameters
-
InputStream | Type of input stream, implementing Stream concept |
Handler | Type of handler, implementing Handler concept. |
- Parameters
-
is | Input stream to be parsed. |
handler | The handler to receive events. |
- Returns
- Whether the parsing is successful.
Definition at line 676 of file reader.h.
template<typename SourceEncoding, typename TargetEncoding, typename StackAllocator = CrtAllocator>
template<unsigned parseFlags, typename SEncoding , typename TEncoding , typename InputStream , typename OutputStream >
RAPIDJSON_FORCEINLINE void GenericReader< SourceEncoding, TargetEncoding, StackAllocator >::ParseStringToStream |
( |
InputStream & |
is, |
|
|
OutputStream & |
os |
|
) |
| |
|
inlineprivate |