123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269 |
- /* vim: set et ts=3 sw=3 sts=3 ft=c:
- *
- * Copyright (C) 2012, 2013, 2014 James McLaughlin et al. All rights reserved.
- * https://github.com/udp/json-parser
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions
- * are met:
- *
- * 1. Redistributions of source code must retain the above copyright
- * notice, this list of conditions and the following disclaimer.
- *
- * 2. Redistributions in binary form must reproduce the above copyright
- * notice, this list of conditions and the following disclaimer in the
- * documentation and/or other materials provided with the distribution.
- *
- * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
- * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
- * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
- * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
- * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
- * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
- * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
- * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
- * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
- * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
- * SUCH DAMAGE.
- */
- #ifndef _JSON_H
- #define _JSON_H
- #ifndef json_char
- #define json_char char
- #endif
- #ifndef json_int_t
- #ifndef _MSC_VER
- #include <inttypes.h>
- #define json_int_t int64_t
- #else
- #define json_int_t __int64
- #endif
- #endif
- #include <stdlib.h>
- #ifdef __cplusplus
- #include <string.h>
- extern "C"
- {
- #endif
- typedef struct
- {
- unsigned long max_memory;
- int settings;
- /* Custom allocator support (leave null to use malloc/free)
- */
- void * (* mem_alloc) (size_t, int zero, void * user_data);
- void (* mem_free) (void *, void * user_data);
- void * user_data; /* will be passed to mem_alloc and mem_free */
- } json_settings;
- #define json_enable_comments 0x01
- typedef enum
- {
- json_none,
- json_object,
- json_array,
- json_integer,
- json_double,
- json_string,
- json_boolean,
- json_null
- } json_type;
- extern const struct _json_value json_value_none;
- typedef struct _json_value
- {
- struct _json_value * parent;
- json_type type;
- union
- {
- int boolean;
- json_int_t integer;
- double dbl;
- struct
- {
- unsigned int length;
- json_char * ptr; /* null terminated */
- } string;
- struct
- {
- unsigned int length;
- struct
- {
- json_char * name;
- unsigned int name_length;
- struct _json_value * value;
- } * values;
- #if defined(__cplusplus) && __cplusplus >= 201103L
- decltype(values) begin () const
- { return values;
- }
- decltype(values) end () const
- { return values + length;
- }
- #endif
- } object;
- struct
- {
- unsigned int length;
- struct _json_value ** values;
- #if defined(__cplusplus) && __cplusplus >= 201103L
- decltype(values) begin () const
- { return values;
- }
- decltype(values) end () const
- { return values + length;
- }
- #endif
- } array;
- } u;
- union
- {
- struct _json_value * next_alloc;
- void * object_mem;
- } _reserved;
- /* Some C++ operator sugar */
- #ifdef __cplusplus
- public:
- inline _json_value ()
- { memset (this, 0, sizeof (_json_value));
- }
- inline const struct _json_value &operator [] (int index) const
- {
- if (type != json_array || index < 0
- || ((unsigned int) index) >= u.array.length)
- {
- return json_value_none;
- }
- return *u.array.values [index];
- }
- inline const struct _json_value &operator [] (const char * index) const
- {
- if (type != json_object)
- return json_value_none;
- for (unsigned int i = 0; i < u.object.length; ++ i)
- if (!strcmp (u.object.values [i].name, index))
- return *u.object.values [i].value;
- return json_value_none;
- }
- inline operator const char * () const
- {
- switch (type)
- {
- case json_string:
- return u.string.ptr;
- default:
- return "";
- };
- }
- inline operator json_int_t () const
- {
- switch (type)
- {
- case json_integer:
- return u.integer;
- case json_double:
- return (json_int_t) u.dbl;
- default:
- return 0;
- };
- }
- inline operator bool () const
- {
- if (type != json_boolean)
- return false;
- return u.boolean != 0;
- }
- inline operator double () const
- {
- switch (type)
- {
- case json_integer:
- return (double) u.integer;
- case json_double:
- return u.dbl;
- default:
- return 0;
- };
- }
- #endif
- } json_value;
- json_value * json_parse (const json_char * json,
- size_t length);
- #define json_error_max 128
- json_value * json_parse_ex (json_settings * settings,
- const json_char * json,
- size_t length,
- char * error);
- void json_value_free (json_value *);
- /* Not usually necessary, unless you used a custom mem_alloc and now want to
- * use a custom mem_free.
- */
- void json_value_free_ex (json_settings * settings,
- json_value *);
- #ifdef __cplusplus
- } /* extern "C" */
- #endif
- #endif
|