mirror of
https://github.com/ekeeke/Genesis-Plus-GX.git
synced 2025-01-03 23:21:51 +01:00
1041 lines
45 KiB
C
1041 lines
45 KiB
C
|
/*
|
||
|
Copyright (c) 2012 John-Anthony Owens
|
||
|
|
||
|
Permission is hereby granted, free of charge, to any person obtaining a
|
||
|
copy of this software and associated documentation files (the "Software"),
|
||
|
to deal in the Software without restriction, including without limitation
|
||
|
the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||
|
and/or sell copies of the Software, and to permit persons to whom the
|
||
|
Software is furnished to do so, subject to the following conditions:
|
||
|
|
||
|
The above copyright notice and this permission notice shall be included
|
||
|
in all copies or substantial portions of the Software.
|
||
|
|
||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
||
|
FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
|
||
|
IN THE SOFTWARE.
|
||
|
*/
|
||
|
|
||
|
#ifndef JSONSAX_H_INCLUDED
|
||
|
#define JSONSAX_H_INCLUDED
|
||
|
|
||
|
/* The library version */
|
||
|
#define JSON_MAJOR_VERSION 1
|
||
|
#define JSON_MINOR_VERSION 4
|
||
|
#define JSON_MICRO_VERSION 5
|
||
|
|
||
|
/* JSON_NO_PARSER and JSON_NO_WRITER, if defined, remove the corresponding
|
||
|
* APIs and functionality from the library.
|
||
|
*/
|
||
|
#if defined(JSON_NO_PARSER) && defined(JSON_NO_WRITER)
|
||
|
#error JSON_NO_PARSER and JSON_NO_WRITER cannot both be defined!
|
||
|
#endif
|
||
|
|
||
|
#include <stddef.h> /* for size_t and NULL */
|
||
|
|
||
|
/* The library API is C and should not be subjected to C++ name mangling. */
|
||
|
#ifdef __cplusplus
|
||
|
extern "C" {
|
||
|
#endif
|
||
|
|
||
|
/* JSON_EXPORT controls the library's public API import/export linkage
|
||
|
* specifiers. By default, the library will be compiled to support dynamic
|
||
|
* linkage. In order to build the library for static linkage, the JSON_STATIC
|
||
|
* macro must be defined when the library itself is built AND when the client
|
||
|
* includes jsonsax.h.
|
||
|
*/
|
||
|
#if defined(JSON_STATIC)
|
||
|
#define JSON_EXPORT /* nothing */
|
||
|
#else
|
||
|
#if defined(_MSC_VER)
|
||
|
#if defined(JSON_BUILDING)
|
||
|
#define JSON_EXPORT __declspec(dllexport)
|
||
|
#else
|
||
|
#define JSON_EXPORT __declspec(dllimport)
|
||
|
#endif
|
||
|
#else
|
||
|
#if defined(JSON_BUILDING)
|
||
|
#define JSON_EXPORT __attribute__ ((visibility("default")))
|
||
|
#else
|
||
|
#define JSON_EXPORT /* nothing */
|
||
|
#endif
|
||
|
#endif
|
||
|
#endif
|
||
|
|
||
|
/* JSON_CALL controls the library's public API calling-convention. Clients'
|
||
|
* handler functions should be declared with JSON_CALL in order to ensure
|
||
|
* that the calling convention matches.
|
||
|
*/
|
||
|
#ifndef JSON_CALL
|
||
|
#if defined(_MSC_VER)
|
||
|
#define JSON_CALL __cdecl
|
||
|
#elif defined(__GNUC__) && defined(__i386) && !defined(__INTEL_COMPILER)
|
||
|
#define JSON_CALL __attribute__((cdecl))
|
||
|
#else
|
||
|
#define JSON_CALL /* nothing */
|
||
|
#endif
|
||
|
#endif
|
||
|
|
||
|
#define JSON_API(t) JSON_EXPORT t JSON_CALL
|
||
|
|
||
|
/* Boolean values used by the library. */
|
||
|
typedef enum tag_JSON_Boolean
|
||
|
{
|
||
|
JSON_False = 0,
|
||
|
JSON_True = 1
|
||
|
} JSON_Boolean;
|
||
|
|
||
|
/* Values returned by library APIs to indicate success or failure. */
|
||
|
typedef enum tag_JSON_Status
|
||
|
{
|
||
|
JSON_Failure = 0,
|
||
|
JSON_Success = 1
|
||
|
} JSON_Status;
|
||
|
|
||
|
/* Error codes. */
|
||
|
typedef enum tag_JSON_Error
|
||
|
{
|
||
|
JSON_Error_None = 0,
|
||
|
JSON_Error_OutOfMemory = 1,
|
||
|
JSON_Error_AbortedByHandler = 2,
|
||
|
JSON_Error_BOMNotAllowed = 3,
|
||
|
JSON_Error_InvalidEncodingSequence = 4,
|
||
|
JSON_Error_UnknownToken = 5,
|
||
|
JSON_Error_UnexpectedToken = 6,
|
||
|
JSON_Error_IncompleteToken = 7,
|
||
|
JSON_Error_ExpectedMoreTokens = 8,
|
||
|
JSON_Error_UnescapedControlCharacter = 9,
|
||
|
JSON_Error_InvalidEscapeSequence = 10,
|
||
|
JSON_Error_UnpairedSurrogateEscapeSequence = 11,
|
||
|
JSON_Error_TooLongString = 12,
|
||
|
JSON_Error_InvalidNumber = 13,
|
||
|
JSON_Error_TooLongNumber = 14,
|
||
|
JSON_Error_DuplicateObjectMember = 15,
|
||
|
JSON_Error_StoppedAfterEmbeddedDocument = 16
|
||
|
} JSON_Error;
|
||
|
|
||
|
/* Text encodings. */
|
||
|
typedef enum tag_JSON_Encoding
|
||
|
{
|
||
|
JSON_UnknownEncoding = 0,
|
||
|
JSON_UTF8 = 1,
|
||
|
JSON_UTF16LE = 2,
|
||
|
JSON_UTF16BE = 3,
|
||
|
JSON_UTF32LE = 4,
|
||
|
JSON_UTF32BE = 5
|
||
|
} JSON_Encoding;
|
||
|
|
||
|
/* Attributes of a string value. */
|
||
|
typedef enum tag_JSON_StringAttribute
|
||
|
{
|
||
|
JSON_SimpleString = 0,
|
||
|
JSON_ContainsNullCharacter = 1 << 0, /* U+0000 */
|
||
|
JSON_ContainsControlCharacter = 1 << 1, /* U+0000 - U+001F */
|
||
|
JSON_ContainsNonASCIICharacter = 1 << 2, /* U+0080 - U+10FFFF */
|
||
|
JSON_ContainsNonBMPCharacter = 1 << 3, /* U+10000 - U+10FFFF */
|
||
|
JSON_ContainsReplacedCharacter = 1 << 4 /* an invalid encoding sequence was replaced by U+FFFD */
|
||
|
} JSON_StringAttribute;
|
||
|
typedef unsigned int JSON_StringAttributes;
|
||
|
|
||
|
/* Attributes of a number value. */
|
||
|
typedef enum tag_JSON_NumberAttribute
|
||
|
{
|
||
|
JSON_SimpleNumber = 0,
|
||
|
JSON_IsNegative = 1 << 0,
|
||
|
JSON_IsHex = 1 << 1,
|
||
|
JSON_ContainsDecimalPoint = 1 << 2,
|
||
|
JSON_ContainsExponent = 1 << 3,
|
||
|
JSON_ContainsNegativeExponent = 1 << 4
|
||
|
} JSON_NumberAttribute;
|
||
|
typedef unsigned int JSON_NumberAttributes;
|
||
|
|
||
|
/* Types of "special" number. */
|
||
|
typedef enum tag_JSON_SpecialNumber
|
||
|
{
|
||
|
JSON_NaN = 0,
|
||
|
JSON_Infinity = 1,
|
||
|
JSON_NegativeInfinity = 2
|
||
|
} JSON_SpecialNumber;
|
||
|
|
||
|
/* Information identifying a location in a parser instance's input stream. */
|
||
|
typedef struct tag_JSON_Location
|
||
|
{
|
||
|
/* The zero-based index of the byte in the input stream. Note that this
|
||
|
* is the only value that unambiguously identifies the location, since
|
||
|
* line and column refer to characters (which may be encoded in the input
|
||
|
* as multi-byte sequences) rather than bytes.
|
||
|
*/
|
||
|
size_t byte;
|
||
|
|
||
|
/* The zero-based line number of the character in the input stream. Note
|
||
|
* that the parser treats each of the following character sequences as a
|
||
|
* single line break for purposes of computing line numbers:
|
||
|
*
|
||
|
* U+000A (LINE FEED)
|
||
|
* U+000D (CARRIAGE RETURN)
|
||
|
* U+000D U+000A (CARRIAGE RETURN, LINE FEED)
|
||
|
*
|
||
|
*/
|
||
|
size_t line;
|
||
|
|
||
|
/* The zero-based column number of the character in the input stream. */
|
||
|
size_t column;
|
||
|
|
||
|
/* The zero-based depth in the JSON document structure at the location. */
|
||
|
size_t depth;
|
||
|
} JSON_Location;
|
||
|
|
||
|
/* Custom memory management handlers.
|
||
|
*
|
||
|
* The semantics of these handlers correspond exactly to those of standard
|
||
|
* realloc(), and free(). The handlers also receive the value of the memory
|
||
|
* suite's user data parameter, which clients can use to implement memory
|
||
|
* pools or impose custom allocation limits, if desired.
|
||
|
*/
|
||
|
typedef void* (JSON_CALL * JSON_ReallocHandler)(void* userData, void* ptr, size_t size);
|
||
|
typedef void (JSON_CALL * JSON_FreeHandler)(void* userData, void* ptr);
|
||
|
|
||
|
/* A suite of custom memory management functions. */
|
||
|
typedef struct tag_JSON_MemorySuite
|
||
|
{
|
||
|
void* userData;
|
||
|
JSON_ReallocHandler realloc;
|
||
|
JSON_FreeHandler free;
|
||
|
} JSON_MemorySuite;
|
||
|
|
||
|
/******************** JSON Parser ********************/
|
||
|
|
||
|
#ifndef JSON_NO_PARSER
|
||
|
|
||
|
/* Parser instance. */
|
||
|
struct JSON_Parser_Data; /* opaque data */
|
||
|
typedef struct JSON_Parser_Data* JSON_Parser;
|
||
|
|
||
|
/* Create a parser instance.
|
||
|
*
|
||
|
* If pMemorySuite is null, the library will use the C runtime realloc() and
|
||
|
* free() as the parser's memory management suite. Otherwise, all the
|
||
|
* handlers in the memory suite must be non-null or the call will fail and
|
||
|
* return null.
|
||
|
*/
|
||
|
JSON_API(JSON_Parser) JSON_Parser_Create(const JSON_MemorySuite* pMemorySuite);
|
||
|
|
||
|
/* Free a parser instance.
|
||
|
*
|
||
|
* Every successful call to JSON_Parser_Create() must eventually be paired
|
||
|
* with a call to JSON_Parser_Free() in order to avoid leaking memory.
|
||
|
*
|
||
|
* This function returns failure if the parser parameter is null or if the
|
||
|
* function was called reentrantly from inside a handler.
|
||
|
*/
|
||
|
JSON_API(JSON_Status) JSON_Parser_Free(JSON_Parser parser);
|
||
|
|
||
|
/* Reset a parser instance so that it can be used to parse a new input stream.
|
||
|
*
|
||
|
* This function returns failure if the parser parameter is null or if the
|
||
|
* function was called reentrantly from inside a handler.
|
||
|
*
|
||
|
* After a parser is reset, its state is indistinguishable from its state
|
||
|
* when it was returned by JSON_Parser_Create(). The parser's custom memory
|
||
|
* suite, if any, is preserved; all other settings, state, and handlers are
|
||
|
* restored to their default values.
|
||
|
*/
|
||
|
JSON_API(JSON_Status) JSON_Parser_Reset(JSON_Parser parser);
|
||
|
|
||
|
/* Get and set the user data value associated with a parser instance.
|
||
|
*
|
||
|
* This setting allows clients to associate additional data with a
|
||
|
* parser instance. The parser itself does not use the value.
|
||
|
*
|
||
|
* The default value of this setting is null.
|
||
|
*
|
||
|
* This setting can be changed at any time, even inside handlers.
|
||
|
*/
|
||
|
JSON_API(void*) JSON_Parser_GetUserData(JSON_Parser parser);
|
||
|
JSON_API(JSON_Status) JSON_Parser_SetUserData(JSON_Parser parser, void* userData);
|
||
|
|
||
|
/* Get and set the input encoding for a parser instance.
|
||
|
*
|
||
|
* If the client does not explicitly set the input encoding before calling
|
||
|
* JSON_Parser_Parse() on the parser instance, the parser will use the first
|
||
|
* 4 bytes of input to detect the input encoding automatically. Once the
|
||
|
* parser has detected the encoding, calls to JSON_Parser_GetInputEncoding()
|
||
|
* will return the detected value.
|
||
|
*
|
||
|
* The default value of this setting is JSON_UnknownEncoding.
|
||
|
*
|
||
|
* This setting cannot be changed once the parser has started parsing.
|
||
|
*/
|
||
|
JSON_API(JSON_Encoding) JSON_Parser_GetInputEncoding(JSON_Parser parser);
|
||
|
JSON_API(JSON_Status) JSON_Parser_SetInputEncoding(JSON_Parser parser, JSON_Encoding encoding);
|
||
|
|
||
|
/* Get and set the string encoding for a parser instance.
|
||
|
*
|
||
|
* This setting controls the encoding of the string values that are
|
||
|
* passed to the string and object member handlers.
|
||
|
*
|
||
|
* The default value of this setting is JSON_UTF8.
|
||
|
*
|
||
|
* This setting cannot be set to JSON_UnknownEncoding.
|
||
|
*
|
||
|
* This setting cannot be changed once the parser has started parsing.
|
||
|
*/
|
||
|
JSON_API(JSON_Encoding) JSON_Parser_GetStringEncoding(JSON_Parser parser);
|
||
|
JSON_API(JSON_Status) JSON_Parser_SetStringEncoding(JSON_Parser parser, JSON_Encoding encoding);
|
||
|
|
||
|
/* Get and set the maximum length of strings that a parser instance allows.
|
||
|
*
|
||
|
* This setting controls the maximum length, in bytes (NOT characters), of
|
||
|
* the encoded strings that are passed to the string and object member
|
||
|
* handlers. If the parser encounters a string that, when encoded in the
|
||
|
* string encoding, is longer than the maximum string length, it triggers
|
||
|
* the JSON_TooLongString error.
|
||
|
*
|
||
|
* The default value of this setting is SIZE_MAX.
|
||
|
*
|
||
|
* This setting cannot be changed once the parser has started parsing.
|
||
|
*/
|
||
|
JSON_API(size_t) JSON_Parser_GetMaxStringLength(JSON_Parser parser);
|
||
|
JSON_API(JSON_Status) JSON_Parser_SetMaxStringLength(JSON_Parser parser, size_t maxLength);
|
||
|
|
||
|
/* Get and set the number encoding for a parser instance.
|
||
|
*
|
||
|
* This setting controls the encoding of the number values that are
|
||
|
* passed to the number handler.
|
||
|
*
|
||
|
* The default value of this setting is JSON_UTF8.
|
||
|
*
|
||
|
* This setting cannot be set to JSON_UnknownEncoding.
|
||
|
*
|
||
|
* This setting cannot be changed once the parser has started parsing.
|
||
|
*/
|
||
|
JSON_API(JSON_Encoding) JSON_Parser_GetNumberEncoding(JSON_Parser parser);
|
||
|
JSON_API(JSON_Status) JSON_Parser_SetNumberEncoding(JSON_Parser parser, JSON_Encoding encoding);
|
||
|
|
||
|
/* Get and set the maximum length of numbers that a parser instance allows.
|
||
|
*
|
||
|
* This setting controls the maximum length, in bytes (NOT characters), of
|
||
|
* the encoded numbers that are passed to the number handler. If the parser
|
||
|
* encounters a number that, when encoded in the number encoding, is longer
|
||
|
* than the maximum number length, it triggers the JSON_TooLongNumber error.
|
||
|
*
|
||
|
* The default value of this setting is SIZE_MAX.
|
||
|
*
|
||
|
* This setting cannot be changed once the parser has started parsing.
|
||
|
*/
|
||
|
JSON_API(size_t) JSON_Parser_GetMaxNumberLength(JSON_Parser parser);
|
||
|
JSON_API(JSON_Status) JSON_Parser_SetMaxNumberLength(JSON_Parser parser, size_t maxLength);
|
||
|
|
||
|
/* Get and set whether a parser instance allows the input to begin with a
|
||
|
* byte-order-mark (BOM).
|
||
|
*
|
||
|
* RFC 4627 does not allow JSON text to begin with a BOM, but some clients
|
||
|
* may find it convenient to be lenient in this regard; for example, if the
|
||
|
* JSON text is being read from a file that has a BOM.
|
||
|
*
|
||
|
* The default value of this setting is JSON_False.
|
||
|
*
|
||
|
* This setting cannot be changed once the parser has started parsing.
|
||
|
*/
|
||
|
JSON_API(JSON_Boolean) JSON_Parser_GetAllowBOM(JSON_Parser parser);
|
||
|
JSON_API(JSON_Status) JSON_Parser_SetAllowBOM(JSON_Parser parser, JSON_Boolean allowBOM);
|
||
|
|
||
|
/* Get and set whether a parser instance allows Javascript-style comments to
|
||
|
* appear in the JSON text.
|
||
|
*
|
||
|
* RFC 4627 does not allow JSON text to contain comments, but some clients
|
||
|
* may find it useful to allow them.
|
||
|
*
|
||
|
* Both types of comment described by ECMA-262 (multi-line and single-line)
|
||
|
* are supported.
|
||
|
*
|
||
|
* The default value of this setting is JSON_False.
|
||
|
*
|
||
|
* This setting cannot be changed once the parser has started parsing.
|
||
|
*/
|
||
|
JSON_API(JSON_Boolean) JSON_Parser_GetAllowComments(JSON_Parser parser);
|
||
|
JSON_API(JSON_Status) JSON_Parser_SetAllowComments(JSON_Parser parser, JSON_Boolean allowComments);
|
||
|
|
||
|
/* Get and set whether a parser instance allows the "special" number literals
|
||
|
* NaN, Infinity, and -Infinity.
|
||
|
*
|
||
|
* RFC 4627 does not provide any way to represent NaN, Infinity, or -Infinity,
|
||
|
* but some clients may find it convenient to recognize these as literals,
|
||
|
* since they are emitted by many common JSON generators.
|
||
|
*
|
||
|
* The default value of this setting is JSON_False.
|
||
|
*
|
||
|
* This setting cannot be changed once the parser has started parsing.
|
||
|
*/
|
||
|
JSON_API(JSON_Boolean) JSON_Parser_GetAllowSpecialNumbers(JSON_Parser parser);
|
||
|
JSON_API(JSON_Status) JSON_Parser_SetAllowSpecialNumbers(JSON_Parser parser, JSON_Boolean allowSpecialNumbers);
|
||
|
|
||
|
/* Get and set whether a parser instance allows hexadecimal notation to be
|
||
|
* used for specifying number values.
|
||
|
*
|
||
|
* RFC 4627 does not allow hexadecimal numbers, but some clients may find it
|
||
|
* convenient to allow them, in order to represent binary bit patterns more
|
||
|
* easily.
|
||
|
*
|
||
|
* The parser recognizes hexadecimal numbers that conform to the syntax of
|
||
|
* HexIntegerLiteral, as described in section 7.8.3 of ECMA-262. That is, a
|
||
|
* valid hexadecimal number must comprise the prefix '0x' or '0X', followed
|
||
|
* by a sequence of one or more of the following characters: '0' - '9',
|
||
|
* 'a' - 'f', and 'A' - 'F'.
|
||
|
*
|
||
|
* Hexadecimal numbers cannot be prefixed by a minus sign.
|
||
|
*
|
||
|
* The default value of this setting is JSON_False.
|
||
|
*
|
||
|
* This setting cannot be changed once the parser has started parsing.
|
||
|
*/
|
||
|
JSON_API(JSON_Boolean) JSON_Parser_GetAllowHexNumbers(JSON_Parser parser);
|
||
|
JSON_API(JSON_Status) JSON_Parser_SetAllowHexNumbers(JSON_Parser parser, JSON_Boolean allowHexNumbers);
|
||
|
|
||
|
/* Get and set whether a parser instance allows unescaped control characters
|
||
|
* (U+0000 - U+001F) to appear inside string values.
|
||
|
*
|
||
|
* RFC 4627 does not allow JSON text to contain unescaped control characters,
|
||
|
* but some clients may find it useful to allow them.
|
||
|
*
|
||
|
* The default value of this setting is JSON_False.
|
||
|
*
|
||
|
* This setting cannot be changed once the parser has started parsing.
|
||
|
*/
|
||
|
JSON_API(JSON_Boolean) JSON_Parser_GetAllowUnescapedControlCharacters(JSON_Parser parser);
|
||
|
JSON_API(JSON_Status) JSON_Parser_SetAllowUnescapedControlCharacters(JSON_Parser parser, JSON_Boolean allowUnescapedControlCharacters);
|
||
|
|
||
|
/* Get and set whether a parser instance replaces invalid encoding sequences
|
||
|
* it encounters inside string tokens with the Unicode replacement character
|
||
|
* (U+FFFD) rather than triggering an error.
|
||
|
*
|
||
|
* By default, the parser is strict when decoding the input stream, and will
|
||
|
* fail if it encounters an encoding sequence that is not valid for the input
|
||
|
* encoding. Note especially that this includes (but is not limited to) the
|
||
|
* following:
|
||
|
*
|
||
|
* - Overlong encoding sequences in UTF-8.
|
||
|
* - Surrogate codepoints encoded in UTF-8 or UTF-32.
|
||
|
* - Unpaired or improperly-paired surrogates in UTF-16.
|
||
|
* - Codepoints outside the Unicode range encoded in UTF-8 or UTF-32.
|
||
|
*
|
||
|
* The replacement follows the rules and recommendations described in section
|
||
|
* 3.9 of version 5.2.0 of [the Unicode Standard](http://www.unicode.org/versions/Unicode5.2.0/).
|
||
|
*
|
||
|
* The default value of this setting is JSON_False.
|
||
|
*
|
||
|
* This setting cannot be changed once the parser has started parsing.
|
||
|
*/
|
||
|
JSON_API(JSON_Boolean) JSON_Parser_GetReplaceInvalidEncodingSequences(JSON_Parser parser);
|
||
|
JSON_API(JSON_Status) JSON_Parser_SetReplaceInvalidEncodingSequences(JSON_Parser parser, JSON_Boolean replaceInvalidEncodingSequences);
|
||
|
|
||
|
/* Get and set whether a parser instance tracks object member names for all
|
||
|
* open objects and detects duplicate members if any occur in the input.
|
||
|
*
|
||
|
* RFC 4627 stipulates that JSON parsers SHOULD check for duplicates, but
|
||
|
* may opt not to in light of reasonable implementation considerations.
|
||
|
* Checking for duplicate members necessarily incurs non-trivial memory
|
||
|
* overhead, and is therefore not enabled by default. Most clients use
|
||
|
* their parse handlers to build some sort of in-memory DOM representation
|
||
|
* of the JSON text and therefore already have the means to check for
|
||
|
* duplicate member names without incurring additional memory overhead; it
|
||
|
* is recommended that these clients implement duplicate member checking
|
||
|
* in their object member handler (refer to SetObjectMemberHandler() for
|
||
|
* details) and leave this setting disabled.
|
||
|
*
|
||
|
* The default value of this setting is JSON_False.
|
||
|
*
|
||
|
* This setting cannot be changed once the parser has started parsing.
|
||
|
*/
|
||
|
JSON_API(JSON_Boolean) JSON_Parser_GetTrackObjectMembers(JSON_Parser parser);
|
||
|
JSON_API(JSON_Status) JSON_Parser_SetTrackObjectMembers(JSON_Parser parser, JSON_Boolean trackObjectMembers);
|
||
|
|
||
|
/* Get and set whether a parser instance stops parsing as soon as the end of
|
||
|
* the top-level JSON document is parsed.
|
||
|
*
|
||
|
* This setting allows the client to parse JSON content that is embedded
|
||
|
* inside a larger data stream. If this setting is enabled, the parser will,
|
||
|
* upon successfully parsing the end of the embedded JSON document, set its
|
||
|
* error to JSON_Error_StoppedAfterEmbeddedDocument, set its error location
|
||
|
* to the location in the input stream immediately following the end of the
|
||
|
* document, and return JSON_Failure from JSON_Parser_Parse().
|
||
|
*
|
||
|
* The default value of this setting is JSON_False.
|
||
|
*
|
||
|
* This setting cannot be changed once the parser has started parsing.
|
||
|
*/
|
||
|
JSON_API(JSON_Boolean) JSON_Parser_GetStopAfterEmbeddedDocument(JSON_Parser parser);
|
||
|
JSON_API(JSON_Status) JSON_Parser_SetStopAfterEmbeddedDocument(JSON_Parser parser, JSON_Boolean stopAfterEmbeddedDocument);
|
||
|
|
||
|
/* Get the type of error, if any, encountered by a parser instance.
|
||
|
*
|
||
|
* If the parser encountered an error while parsing input, this function
|
||
|
* returns the type of the error. Otherwise, this function returns
|
||
|
* JSON_Error_None.
|
||
|
*/
|
||
|
JSON_API(JSON_Error) JSON_Parser_GetError(JSON_Parser parser);
|
||
|
|
||
|
/* Get the location in the input stream at which a parser instance
|
||
|
* encountered an error.
|
||
|
*
|
||
|
* If the parser encountered an error while parsing input, this function
|
||
|
* sets the members of the structure pointed to by pLocation to the location
|
||
|
* in the input stream at which the error occurred and returns success.
|
||
|
* Otherwise, it leaves the members unchanged and returns failure.
|
||
|
*/
|
||
|
JSON_API(JSON_Status) JSON_Parser_GetErrorLocation(JSON_Parser parser, JSON_Location* pLocation);
|
||
|
|
||
|
/* Get the location in the input stream of the beginning of the token
|
||
|
* that is currently being handled by one of a parser instance's parse
|
||
|
* handlers.
|
||
|
*
|
||
|
* If the parser is inside a parse handler, this function sets the members
|
||
|
* of the structure pointed to by pLocation to the location and returns
|
||
|
* success. Otherwise, it leaves the members unchanged and returns failure.
|
||
|
*/
|
||
|
JSON_API(JSON_Status) JSON_Parser_GetTokenLocation(JSON_Parser parser, JSON_Location* pLocation);
|
||
|
|
||
|
/* Get the location in the input stream that immediately follows the end of
|
||
|
* the token that is currently being handled by one of a parser instance's
|
||
|
* parse handlers.
|
||
|
*
|
||
|
* If the parser is inside a parse handler, this function sets the members
|
||
|
* of the structure pointed to by pLocation to the location and returns
|
||
|
* success. Otherwise, it leaves the members unchanged and returns failure.
|
||
|
*/
|
||
|
JSON_API(JSON_Status) JSON_Parser_GetAfterTokenLocation(JSON_Parser parser, JSON_Location* pLocation);
|
||
|
|
||
|
/* Parse handlers are callbacks that the client provides in order to
|
||
|
* be notified about the structure of the JSON document as it is being
|
||
|
* parsed. The following notes apply equally to all parse handlers:
|
||
|
*
|
||
|
* 1. Parse handlers are optional. In fact, a parser with no parse
|
||
|
* handlers at all can be used to simply validate that the input
|
||
|
* is valid JSON.
|
||
|
*
|
||
|
* 2. Parse handlers can be set, unset, or changed at any time, even
|
||
|
* from inside a parse handler.
|
||
|
*
|
||
|
* 3. If a parse handler returns JSON_Parser_Abort, the parser will
|
||
|
* abort the parse, set its error to JSON_Error_AbortedByHandler,
|
||
|
* set its error location to the start of the token that triggered
|
||
|
* the handler, and return JSON_Failure from the outer call to
|
||
|
* JSON_Parser_Parse().
|
||
|
*
|
||
|
* 4. A parse handler can get the location in the input stream of the
|
||
|
* token that triggered the handler by calling
|
||
|
* JSON_Parser_GetTokenLocation().
|
||
|
*/
|
||
|
|
||
|
/* Values returned by parse handlers to indicate whether parsing should
|
||
|
* continue or be aborted.
|
||
|
*
|
||
|
* Note that JSON_TreatAsDuplicateObjectMember should only be returned by
|
||
|
* object member handlers. Refer to JSON_Parser_SetObjectMemberHandler()
|
||
|
* for details.
|
||
|
*/
|
||
|
typedef enum tag_JSON_Parser_HandlerResult
|
||
|
{
|
||
|
JSON_Parser_Continue = 0,
|
||
|
JSON_Parser_Abort = 1,
|
||
|
JSON_Parser_TreatAsDuplicateObjectMember = 2
|
||
|
} JSON_Parser_HandlerResult;
|
||
|
|
||
|
/* Get and set the handler that is called when a parser instance detects the
|
||
|
* input encoding.
|
||
|
*
|
||
|
* If the parser instance's input encoding was set to JSON_UnknownEncoding
|
||
|
* when parsing began, this handler will be called as soon as the actual
|
||
|
* input encoding has been detected.
|
||
|
*
|
||
|
* Note that JSON_Parser_GetTokenLocation() will return failure if called
|
||
|
* from inside this handler, since there is no token associated with this
|
||
|
* event.
|
||
|
*/
|
||
|
typedef JSON_Parser_HandlerResult (JSON_CALL * JSON_Parser_EncodingDetectedHandler)(JSON_Parser parser);
|
||
|
JSON_API(JSON_Parser_EncodingDetectedHandler) JSON_Parser_GetEncodingDetectedHandler(JSON_Parser parser);
|
||
|
JSON_API(JSON_Status) JSON_Parser_SetEncodingDetectedHandler(JSON_Parser parser, JSON_Parser_EncodingDetectedHandler handler);
|
||
|
|
||
|
/* Get and set the handler that is called when a parser instance encounters
|
||
|
* a JSON null literal value.
|
||
|
*/
|
||
|
typedef JSON_Parser_HandlerResult (JSON_CALL * JSON_Parser_NullHandler)(JSON_Parser parser);
|
||
|
JSON_API(JSON_Parser_NullHandler) JSON_Parser_GetNullHandler(JSON_Parser parser);
|
||
|
JSON_API(JSON_Status) JSON_Parser_SetNullHandler(JSON_Parser parser, JSON_Parser_NullHandler handler);
|
||
|
|
||
|
/* Get and set the handler that is called when a parser instance encounters
|
||
|
* a JSON boolean value (true or false).
|
||
|
*/
|
||
|
typedef JSON_Parser_HandlerResult (JSON_CALL * JSON_Parser_BooleanHandler)(JSON_Parser parser, JSON_Boolean value);
|
||
|
JSON_API(JSON_Parser_BooleanHandler) JSON_Parser_GetBooleanHandler(JSON_Parser parser);
|
||
|
JSON_API(JSON_Status) JSON_Parser_SetBooleanHandler(JSON_Parser parser, JSON_Parser_BooleanHandler handler);
|
||
|
|
||
|
/* Get and set the handler that is called when a parser instance encounters
|
||
|
* a JSON string value.
|
||
|
*
|
||
|
* The pValue parameter points to a buffer containing the string value,
|
||
|
* encoded according to the parser instance's string encoding setting. The
|
||
|
* buffer is null-terminated (the null terminator character is also encoded).
|
||
|
* Note, however, that JSON strings may contain embedded null characters,
|
||
|
* which are specifiable using the escape sequence \u0000. The client is
|
||
|
* free to modify the contents of the buffer during the handler.
|
||
|
*
|
||
|
* The length parameter specifies the number of bytes (NOT characters) in
|
||
|
* the encoded string, not including the encoded null terminator.
|
||
|
*
|
||
|
* The attributes parameter provides information about the characters
|
||
|
* that comprise the string. If the option to replace invalid encoding
|
||
|
* sequences is enabled and the string contains any Unicode replacement
|
||
|
* characters (U+FFFD) that were the result of replacing invalid encoding
|
||
|
* sequences in the input, the attributes will include the value
|
||
|
* JSON_ContainsReplacedCharacter. Note that the absence of this attribute
|
||
|
* does not imply that the string does not contain any U+FFFD characters,
|
||
|
* since such characters may have been present in the original input, and
|
||
|
* not inserted by a replacement operation.
|
||
|
*/
|
||
|
typedef JSON_Parser_HandlerResult (JSON_CALL * JSON_Parser_StringHandler)(JSON_Parser parser, char* pValue, size_t length, JSON_StringAttributes attributes);
|
||
|
JSON_API(JSON_Parser_StringHandler) JSON_Parser_GetStringHandler(JSON_Parser parser);
|
||
|
JSON_API(JSON_Status) JSON_Parser_SetStringHandler(JSON_Parser parser, JSON_Parser_StringHandler handler);
|
||
|
|
||
|
/* Get and set the handler that is called when a parser instance encounters
|
||
|
* a JSON number value.
|
||
|
*
|
||
|
* JSON numbers do not have a defined binary representation or precision,
|
||
|
* and different clients may wish to interpret them differently, for
|
||
|
* example, as IEEE 754 doubles, 64-bit integers, or arbitrary-precision
|
||
|
* bignums. For this reason, the parser does not attempt to interpret
|
||
|
* number values, but leaves this to the client.
|
||
|
*
|
||
|
* The pValue parameter points to a buffer containing the number value,
|
||
|
* encoded according to the parser instance's number encoding setting. The
|
||
|
* buffer is null-terminated (the null terminator character is also encoded).
|
||
|
* The buffer is guaranteed to contain only characters allowed in JSON number
|
||
|
* values, that is: '0' - '9', '+', '-', '.', 'e', and 'E'; if the option
|
||
|
* to allow hex numbers is enabled, the text may also contain the characters
|
||
|
* 'x', 'X', 'a' - 'f', and 'A' - 'F'. The client is free to modify the
|
||
|
* contents of the buffer during the handler. This is especially useful
|
||
|
* to clients that wish to convert the number to a double using the C
|
||
|
* standard library's strtod() function, which is locale-sensitive; in this
|
||
|
* case, the client should modify the buffer to replace the '.' character
|
||
|
* with localconv()->decimal_point[0] before passing the buffer to strtod().
|
||
|
*
|
||
|
* The length parameter specifies the number of bytes (NOT characters) in
|
||
|
* the encoded number, not including the encoded null terminator.
|
||
|
*
|
||
|
* The attributes parameter provides information about the number.
|
||
|
*/
|
||
|
typedef JSON_Parser_HandlerResult (JSON_CALL * JSON_Parser_NumberHandler)(JSON_Parser parser, char* pValue, size_t length, JSON_NumberAttributes attributes);
|
||
|
JSON_API(JSON_Parser_NumberHandler) JSON_Parser_GetNumberHandler(JSON_Parser parser);
|
||
|
JSON_API(JSON_Status) JSON_Parser_SetNumberHandler(JSON_Parser parser, JSON_Parser_NumberHandler handler);
|
||
|
|
||
|
/* Get and set the handler that is called when a parser instance encounters
|
||
|
* one of the "special" number literals NaN, Infinity, and -Inifinity.
|
||
|
*/
|
||
|
typedef JSON_Parser_HandlerResult (JSON_CALL * JSON_Parser_SpecialNumberHandler)(JSON_Parser parser, JSON_SpecialNumber value);
|
||
|
JSON_API(JSON_Parser_SpecialNumberHandler) JSON_Parser_GetSpecialNumberHandler(JSON_Parser parser);
|
||
|
JSON_API(JSON_Status) JSON_Parser_SetSpecialNumberHandler(JSON_Parser parser, JSON_Parser_SpecialNumberHandler handler);
|
||
|
|
||
|
/* Get and set the handler that is called when a parser instance encounters
|
||
|
* the left curly brace that starts an object.
|
||
|
*/
|
||
|
typedef JSON_Parser_HandlerResult (JSON_CALL * JSON_Parser_StartObjectHandler)(JSON_Parser parser);
|
||
|
JSON_API(JSON_Parser_StartObjectHandler) JSON_Parser_GetStartObjectHandler(JSON_Parser parser);
|
||
|
JSON_API(JSON_Status) JSON_Parser_SetStartObjectHandler(JSON_Parser parser, JSON_Parser_StartObjectHandler handler);
|
||
|
|
||
|
/* Get and set the handler that is called when a parser instance encounters
|
||
|
* the right curly brace that ends an object.
|
||
|
*/
|
||
|
typedef JSON_Parser_HandlerResult (JSON_CALL * JSON_Parser_EndObjectHandler)(JSON_Parser parser);
|
||
|
JSON_API(JSON_Parser_EndObjectHandler) JSON_Parser_GetEndObjectHandler(JSON_Parser parser);
|
||
|
JSON_API(JSON_Status) JSON_Parser_SetEndObjectHandler(JSON_Parser parser, JSON_Parser_EndObjectHandler handler);
|
||
|
|
||
|
/* Get and set the handler that is called when a parser instance encounters
|
||
|
* an object member name.
|
||
|
*
|
||
|
* The pValue parameter points to a buffer containing the member name,
|
||
|
* encoded according to the parser instance's string encoding setting. The
|
||
|
* buffer is null-terminated (the null terminator character is also encoded).
|
||
|
* Note, however, that JSON strings may contain embedded null characters,
|
||
|
* which are specifiable using the escape sequence \u0000. The client is
|
||
|
* free to modify the contents of the buffer during the handler.
|
||
|
*
|
||
|
* The length parameter specifies the number of bytes (NOT characters) in
|
||
|
* the encoded string, not including the encoded null terminator.
|
||
|
*
|
||
|
* The attributes parameter provides information about the characters
|
||
|
* that comprise the string. If the option to replace invalid encoding
|
||
|
* sequences is enabled and the string contains any Unicode replacement
|
||
|
* characters (U+FFFD) that were the result of replacing invalid encoding
|
||
|
* sequences in the input, the attributes will include the value
|
||
|
* JSON_ContainsReplacedCharacter. Note that the absence of this attribute
|
||
|
* does not imply that the string does not contain any U+FFFD characters,
|
||
|
* since such characters may have been present in the original input, and
|
||
|
* not inserted by a replacement operation.
|
||
|
*
|
||
|
* The handler can return JSON_Parser_TreatAsDuplicateObjectMember to
|
||
|
* indicate that the current object already contains a member with the
|
||
|
* specified name. This allows clients to implement duplicate member
|
||
|
* checking without incurring the additional memory overhead associated
|
||
|
* with enabling the TrackObjectMembers setting.
|
||
|
*/
|
||
|
typedef JSON_Parser_HandlerResult (JSON_CALL * JSON_Parser_ObjectMemberHandler)(JSON_Parser parser, char* pValue, size_t length, JSON_StringAttributes attributes);
|
||
|
JSON_API(JSON_Parser_ObjectMemberHandler) JSON_Parser_GetObjectMemberHandler(JSON_Parser parser);
|
||
|
JSON_API(JSON_Status) JSON_Parser_SetObjectMemberHandler(JSON_Parser parser, JSON_Parser_ObjectMemberHandler handler);
|
||
|
|
||
|
/* Get and set the handler that is called when a parser instance encounters
|
||
|
* the left square brace that starts an array.
|
||
|
*/
|
||
|
typedef JSON_Parser_HandlerResult (JSON_CALL * JSON_Parser_StartArrayHandler)(JSON_Parser parser);
|
||
|
JSON_API(JSON_Parser_StartArrayHandler) JSON_Parser_GetStartArrayHandler(JSON_Parser parser);
|
||
|
JSON_API(JSON_Status) JSON_Parser_SetStartArrayHandler(JSON_Parser parser, JSON_Parser_StartArrayHandler handler);
|
||
|
|
||
|
/* Get and set the handler that is called when a parser instance encounters
|
||
|
* the right square brace that ends an array.
|
||
|
*/
|
||
|
typedef JSON_Parser_HandlerResult (JSON_CALL * JSON_Parser_EndArrayHandler)(JSON_Parser parser);
|
||
|
JSON_API(JSON_Parser_EndArrayHandler) JSON_Parser_GetEndArrayHandler(JSON_Parser parser);
|
||
|
JSON_API(JSON_Status) JSON_Parser_SetEndArrayHandler(JSON_Parser parser, JSON_Parser_EndArrayHandler handler);
|
||
|
|
||
|
/* Get and set the handler that is called when a parser instance encounters
|
||
|
* an array item.
|
||
|
*
|
||
|
* This event is always immediately followed by a null, boolean, string,
|
||
|
* number, special number, start object, or start array event.
|
||
|
*/
|
||
|
typedef JSON_Parser_HandlerResult (JSON_CALL * JSON_Parser_ArrayItemHandler)(JSON_Parser parser);
|
||
|
JSON_API(JSON_Parser_ArrayItemHandler) JSON_Parser_GetArrayItemHandler(JSON_Parser parser);
|
||
|
JSON_API(JSON_Status) JSON_Parser_SetArrayItemHandler(JSON_Parser parser, JSON_Parser_ArrayItemHandler handler);
|
||
|
|
||
|
/* Push zero or more bytes of input to a parser instance.
|
||
|
*
|
||
|
* The pBytes parameter points to a buffer containing the bytes to be
|
||
|
* parsed, if any. pBytes may be NULL if and only if the length parameter
|
||
|
* is 0.
|
||
|
*
|
||
|
* The length parameter specifies the number of bytes (NOT characters)
|
||
|
* pointed to by pBytes.
|
||
|
*
|
||
|
* The isFinal parameter specifies whether the parser should treat the
|
||
|
* input to the call as the last chunk of input in the JSON document.
|
||
|
* If this parameter is JSON_False, the parser will assume that more
|
||
|
* input may be forthcoming.
|
||
|
*
|
||
|
* The parser adheres to [RFC 4627](http://www.ietf.org/rfc/rfc4627.txt),
|
||
|
* except that any JSON value (null, true, false, string, number, object,
|
||
|
* or array) is accepted as a valid top-level entity in the parsed text.
|
||
|
*
|
||
|
* This function returns failure if the parser parameter is null, if the
|
||
|
* function was called reentrantly from inside a handler, or if the
|
||
|
* parser instance has already finished parsing.
|
||
|
*/
|
||
|
JSON_API(JSON_Status) JSON_Parser_Parse(JSON_Parser parser, const char* pBytes, size_t length, JSON_Boolean isFinal);
|
||
|
|
||
|
#endif /* JSON_NO_PARSER */
|
||
|
|
||
|
/******************** JSON Writer ********************/
|
||
|
|
||
|
#ifndef JSON_NO_WRITER
|
||
|
|
||
|
/* Writer instance. */
|
||
|
struct JSON_Writer_Data; /* opaque data */
|
||
|
typedef struct JSON_Writer_Data* JSON_Writer;
|
||
|
|
||
|
/* Create a writer instance.
|
||
|
*
|
||
|
* If pMemorySuite is null, the library will use the C runtime realloc() and
|
||
|
* free() as the writer's memory management suite. Otherwise, all the
|
||
|
* handlers in the memory suite must be non-null or the call will fail and
|
||
|
* return null.
|
||
|
*/
|
||
|
JSON_API(JSON_Writer) JSON_Writer_Create(const JSON_MemorySuite* pMemorySuite);
|
||
|
|
||
|
/* Free a writer instance.
|
||
|
*
|
||
|
* Every successful call to JSON_Writer_Create() must eventually be paired
|
||
|
* with a call to JSON_Writer_Free() in order to avoid leaking memory.
|
||
|
*
|
||
|
* This function returns failure if the writer parameter is null or if the
|
||
|
* function was called reentrantly from inside a handler.
|
||
|
*/
|
||
|
JSON_API(JSON_Status) JSON_Writer_Free(JSON_Writer writer);
|
||
|
|
||
|
/* Reset a writer instance so that it can be used to write a new output
|
||
|
* stream.
|
||
|
*
|
||
|
* This function returns failure if the writer parameter is null or if the
|
||
|
* function was called reentrantly from inside a handler.
|
||
|
*
|
||
|
* After a writer is reset, its state is indistinguishable from its state
|
||
|
* when it was returned by JSON_Writer_Create(). The writer's custom memory
|
||
|
* suite, if any, is preserved; all other settings, state, and handlers are
|
||
|
* restored to their default values.
|
||
|
*/
|
||
|
JSON_API(JSON_Status) JSON_Writer_Reset(JSON_Writer writer);
|
||
|
|
||
|
/* Get and set the user data value associated with a writer instance.
|
||
|
*
|
||
|
* This setting allows clients to associate additional data with a
|
||
|
* writer instance. The writer itself does not use the value.
|
||
|
*
|
||
|
* The default value of this setting is NULL.
|
||
|
*
|
||
|
* This setting can be changed at any time, even inside handlers.
|
||
|
*/
|
||
|
JSON_API(void*) JSON_Writer_GetUserData(JSON_Writer writer);
|
||
|
JSON_API(JSON_Status) JSON_Writer_SetUserData(JSON_Writer writer, void* userData);
|
||
|
|
||
|
/* Get and set the output encoding for a writer instance.
|
||
|
*
|
||
|
* The default value of this setting is JSON_UTF8.
|
||
|
*
|
||
|
* This setting cannot be set to JSON_UnknownEncoding.
|
||
|
*
|
||
|
* This setting cannot be changed once the writer has started writing.
|
||
|
*/
|
||
|
JSON_API(JSON_Encoding) JSON_Writer_GetOutputEncoding(JSON_Writer writer);
|
||
|
JSON_API(JSON_Status) JSON_Writer_SetOutputEncoding(JSON_Writer writer, JSON_Encoding encoding);
|
||
|
|
||
|
/* Get and set whether a writer instance uses CARRIAGE RETURN, LINE FEED
|
||
|
* (CRLF) as the new line sequence generated by JSON_Writer_WriteNewLine().
|
||
|
*
|
||
|
* The default value of this setting is JSON_False.
|
||
|
*
|
||
|
* This setting cannot be changed once the writer has started writing.
|
||
|
*/
|
||
|
JSON_API(JSON_Boolean) JSON_Writer_GetUseCRLF(JSON_Writer writer);
|
||
|
JSON_API(JSON_Status) JSON_Writer_SetUseCRLF(JSON_Writer writer, JSON_Boolean useCRLF);
|
||
|
|
||
|
/* Get and set whether a writer instance replaces invalid encoding sequences
|
||
|
* it encounters in string tokens with the Unicode replacement character
|
||
|
* (U+FFFD) rather than triggering an error.
|
||
|
*
|
||
|
* The default value of this setting is JSON_False.
|
||
|
*
|
||
|
* This setting cannot be changed once the writer has started writing.
|
||
|
*/
|
||
|
JSON_API(JSON_Boolean) JSON_Writer_GetReplaceInvalidEncodingSequences(JSON_Writer writer);
|
||
|
JSON_API(JSON_Status) JSON_Writer_SetReplaceInvalidEncodingSequences(JSON_Writer writer, JSON_Boolean replaceInvalidEncodingSequences);
|
||
|
|
||
|
/* Get and set whether a writer instance escapes all non-ASCII characters
|
||
|
* that it outputs. This can be useful for debugging, or when the output
|
||
|
* will be consumed by a parser that does not support UTF-encoded input.
|
||
|
* It is not recommended as a general practice, since it bloats the size
|
||
|
* of non-ASCII strings considerably, compared to UTF encoding.
|
||
|
*
|
||
|
* The default value of this setting is JSON_False.
|
||
|
*
|
||
|
* This setting cannot be changed once the writer has started writing.
|
||
|
*/
|
||
|
JSON_API(JSON_Boolean) JSON_Writer_GetEscapeAllNonASCIICharacters(JSON_Writer writer);
|
||
|
JSON_API(JSON_Status) JSON_Writer_SetEscapeAllNonASCIICharacters(JSON_Writer writer, JSON_Boolean escapeAllNonASCIICharacters);
|
||
|
|
||
|
/* Get the type of error, if any, encountered by a writer instance.
|
||
|
*
|
||
|
* If the writer encountered an error while writing input, this function
|
||
|
* returns the type of the error. Otherwise, this function returns
|
||
|
* JSON_Error_None.
|
||
|
*/
|
||
|
JSON_API(JSON_Error) JSON_Writer_GetError(JSON_Writer writer);
|
||
|
|
||
|
/* The JSON_Writer_WriteXXX() family of functions cause JSON text to be
|
||
|
* sent to a writer instance's output handler. The following notes apply
|
||
|
* equally to all these functions:
|
||
|
*
|
||
|
* 1. The output handler is optional, and can be set, unset, or changed
|
||
|
* at any time, even from inside the output handler.
|
||
|
*
|
||
|
* 2. A single call to JSON_Writer_WriteXXX() may trigger multiple calls
|
||
|
* to the output handler.
|
||
|
*
|
||
|
* 3. All output generated by a call to JSON_Writer_WriteXXX() is sent
|
||
|
* to the output handler before the call returns; that is, the writer
|
||
|
* does not aggregate output from multiple writes before sending it to
|
||
|
* the output handler.
|
||
|
*
|
||
|
* 4. A call to JSON_Writer_WriteXXX() will fail if the writer has
|
||
|
* already encountered an error.
|
||
|
*
|
||
|
* 5. A call to JSON_Writer_WriteXXX() will fail if the call was made
|
||
|
* reentrantly from inside a handler.
|
||
|
*
|
||
|
* 6. A call to JSON_Writer_WriteXXX() will fail if it would cause the
|
||
|
* writer to output grammatically-incorrect JSON text.
|
||
|
*
|
||
|
* 7. If an output handler returns JSON_Writer_Abort, the writer will
|
||
|
* abort the write, set its error to JSON_Error_AbortedByHandler,
|
||
|
* set its error location to the location in the output stream prior
|
||
|
* to the call to the handler, and return JSON_Failure from the outer
|
||
|
* call to JSON_Writer_WriteXXX().
|
||
|
*/
|
||
|
|
||
|
/* Values returned by write handlers to indicate whether writing should
|
||
|
* continue or be aborted.
|
||
|
*/
|
||
|
typedef enum tag_JSON_Writer_HandlerResult
|
||
|
{
|
||
|
JSON_Writer_Continue = 0,
|
||
|
JSON_Writer_Abort = 1
|
||
|
} JSON_Writer_HandlerResult;
|
||
|
|
||
|
/* Get and set the handler that is called when a writer instance has output
|
||
|
* ready to be written.
|
||
|
*
|
||
|
* The pBytes parameter points to a buffer containing the bytes to be written,
|
||
|
* encoded according to the writer instance's output encoding setting. The
|
||
|
* buffer is NOT null-terminated.
|
||
|
*
|
||
|
* The length parameter specifies the number of bytes (NOT characters) in
|
||
|
* the encoded output.
|
||
|
*/
|
||
|
typedef JSON_Writer_HandlerResult (JSON_CALL * JSON_Writer_OutputHandler)(JSON_Writer writer, const char* pBytes, size_t length);
|
||
|
JSON_API(JSON_Writer_OutputHandler) JSON_Writer_GetOutputHandler(JSON_Writer writer);
|
||
|
JSON_API(JSON_Status) JSON_Writer_SetOutputHandler(JSON_Writer writer, JSON_Writer_OutputHandler handler);
|
||
|
|
||
|
/* Write the JSON null literal to the output. */
|
||
|
JSON_API(JSON_Status) JSON_Writer_WriteNull(JSON_Writer writer);
|
||
|
|
||
|
/* Write a JSON boolean value to the output. */
|
||
|
JSON_API(JSON_Status) JSON_Writer_WriteBoolean(JSON_Writer writer, JSON_Boolean value);
|
||
|
|
||
|
/* Write a JSON string value to the output.
|
||
|
*
|
||
|
* The pValue parameter points to a buffer containing the string to be
|
||
|
* written. The buffer does NOT need to be null-terminated. This
|
||
|
* parameter can be null if and only if the length parameter is zero.
|
||
|
*
|
||
|
* The length parameter specifies the number of bytes (NOT characters)
|
||
|
* in the buffer. If the buffer is null-terminated, the length should
|
||
|
* NOT include the null terminator.
|
||
|
*
|
||
|
* The encoding parameter specifies the encoding of the text pointed
|
||
|
* to by pValue. This parameter cannot be JSON_UnknownEncoding.
|
||
|
*
|
||
|
* If the string contains invalid encoding sequences and the option to
|
||
|
* replace invalid encoding sequences with the Unicode replacement
|
||
|
* character (U+FFFD) is not enabled for the writer instance, the writer
|
||
|
* sets its error to JSON_Error_InvalidEncodingSequence and returns
|
||
|
* failure.
|
||
|
*
|
||
|
* The writer escapes the following codepoints:
|
||
|
*
|
||
|
* - BACKSPACE (U+0008) => \b
|
||
|
* - TAB (U+0009) => \t
|
||
|
* - LINE FEED (U+000A) => \n
|
||
|
* - FORM FEED (U+000C) => \f
|
||
|
* - CARRIAGE RETURN (U+000D) => \r
|
||
|
* - QUOTATION MARK (U+0022) => \"
|
||
|
* - SOLIDUS (U+002F) => \/
|
||
|
* - REVERSE SOLIDUS (U+005C) => \\
|
||
|
*
|
||
|
* The writer also escapes the following codepoints using hex-style escape
|
||
|
* sequences:
|
||
|
*
|
||
|
* - All control characters (U+0000 - U+001F) except those covered by the
|
||
|
* list above.
|
||
|
* - DELETE (U+007F)
|
||
|
* - LINE SEPARATOR (U+2028)
|
||
|
* - PARAGRAPH SEPARATOR (U+2029)
|
||
|
* - All 34 Unicode "noncharacter" codepoints whose values end in FE or FF.
|
||
|
* - All 32 Unicode "noncharacter" codepoints in the range U+FDD0 - U+FDEF.
|
||
|
* - REPLACEMENT CHARACTER (U+FFFD), if it did not appear in the original
|
||
|
* string provided by the client; in other words, if the writer introduced
|
||
|
* it in the output as a replacement for an invalid encoding sequence in
|
||
|
* the original string.
|
||
|
*
|
||
|
* If the setting to escape all non-ASCII characters is enabled, ALL
|
||
|
* codepoints above U+0080 are escaped using hex-style escape sequences.
|
||
|
*/
|
||
|
JSON_API(JSON_Status) JSON_Writer_WriteString(JSON_Writer writer, const char* pValue, size_t length, JSON_Encoding encoding);
|
||
|
|
||
|
/* Write a JSON number value to the output.
|
||
|
*
|
||
|
* The pValue parameter points to a buffer containing the number to be
|
||
|
* written. The buffer does NOT need to be null-terminated.
|
||
|
*
|
||
|
* The length parameter specifies the number of bytes (NOT characters)
|
||
|
* in the buffer. If the buffer is null-terminated, the length should
|
||
|
* NOT include the null terminator.
|
||
|
*
|
||
|
* The encoding parameter specifies the encoding of the text pointed
|
||
|
* to by pValue. This parameter cannot be JSON_UnknownEncoding.
|
||
|
*
|
||
|
* If the number contains an invalid encoding sequence, the writer sets
|
||
|
* its error to JSON_Error_InvalidEncodingSequence and returns failure,
|
||
|
* regardless of whether the option to replace invalid encoding sequences
|
||
|
* with the Unicode replacement character (U+FFFD) is enabled (that
|
||
|
* setting only affects writing of string values).
|
||
|
*
|
||
|
* The number must be a valid JSON number as described by RFC 4627, or a
|
||
|
* hexadecimal number conforming to the syntax of HexIntegerLiteral, as
|
||
|
* described in section 7.8.3 of ECMA-262. Otherwise, the writer sets its
|
||
|
* error to JSON_Error_InvalidNumber and returns failure.
|
||
|
*/
|
||
|
JSON_API(JSON_Status) JSON_Writer_WriteNumber(JSON_Writer writer, const char* pValue, size_t length, JSON_Encoding encoding);
|
||
|
|
||
|
/* Write a JSON "special" number literal to the output. */
|
||
|
JSON_API(JSON_Status) JSON_Writer_WriteSpecialNumber(JSON_Writer writer, JSON_SpecialNumber value);
|
||
|
|
||
|
/* Write a left curly-brace character to the output. */
|
||
|
JSON_API(JSON_Status) JSON_Writer_WriteStartObject(JSON_Writer writer);
|
||
|
|
||
|
/* Write a right curly-brace character to the output. */
|
||
|
JSON_API(JSON_Status) JSON_Writer_WriteEndObject(JSON_Writer writer);
|
||
|
|
||
|
/* Write a left square-brace character to the output. */
|
||
|
JSON_API(JSON_Status) JSON_Writer_WriteStartArray(JSON_Writer writer);
|
||
|
|
||
|
/* Write a right square-brace character to the output. */
|
||
|
JSON_API(JSON_Status) JSON_Writer_WriteEndArray(JSON_Writer writer);
|
||
|
|
||
|
/* Write a colon character to the output. */
|
||
|
JSON_API(JSON_Status) JSON_Writer_WriteColon(JSON_Writer writer);
|
||
|
|
||
|
/* Write a comma character to the output. */
|
||
|
JSON_API(JSON_Status) JSON_Writer_WriteComma(JSON_Writer writer);
|
||
|
|
||
|
/* Write space characters to the output. */
|
||
|
JSON_API(JSON_Status) JSON_Writer_WriteSpace(JSON_Writer writer, size_t numberOfSpaces);
|
||
|
|
||
|
/* Write a newline sequence to the output. */
|
||
|
JSON_API(JSON_Status) JSON_Writer_WriteNewLine(JSON_Writer writer);
|
||
|
|
||
|
#endif /* JSON_NO_WRITER */
|
||
|
|
||
|
/******************** Miscellaneous API ********************/
|
||
|
|
||
|
/* Information about the library version. */
|
||
|
typedef struct tag_JSON_Version
|
||
|
{
|
||
|
unsigned int major;
|
||
|
unsigned int minor;
|
||
|
unsigned int micro;
|
||
|
} JSON_Version;
|
||
|
|
||
|
/* Get a pointer to the library version information. */
|
||
|
JSON_API(const JSON_Version*) JSON_LibraryVersion(void);
|
||
|
|
||
|
/* Get a constant, null-terminated, ASCII string describing an error code. */
|
||
|
JSON_API(const char*) JSON_ErrorString(JSON_Error error);
|
||
|
|
||
|
/* Get the UTF-16 encoding whose endianness matches the target platform.
|
||
|
*
|
||
|
* This function always returns either JSON_UTF16LE or JSON_UTF16BE.
|
||
|
*/
|
||
|
JSON_API(JSON_Encoding) JSON_NativeUTF16Encoding(void);
|
||
|
|
||
|
/* Get the UTF-32 encoding whose endianness matches the target platform.
|
||
|
*
|
||
|
* This function always returns either JSON_UTF32LE or JSON_UTF32BE.
|
||
|
*/
|
||
|
JSON_API(JSON_Encoding) JSON_NativeUTF32Encoding(void);
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
#endif /* JSONSAX_H_INCLUDED */
|