|
| | 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 occured in the last parsing. More...
|
| |
| RAPIDJSON_FORCEINLINE bool | IterativeParseComplete () |
| | 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) |
| |
| RAPIDJSON_FORCEINLINE bool | IsIterativeParsingDelimiterState (IterativeParsingState s) |
| |
| 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) |
| |
| template<unsigned parseFlags, typename InputStream > |
| void | SkipWhitespaceAndComments (InputStream &is) |
| |
| RAPIDJSON_FORCEINLINE Token | Tokenize (Ch c) |
| |
| 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 88 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 619 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 |