2 * Copyright (c) 2009-2016 Petri Lehtinen <petri@digip.org>
4 * Jansson is free software; you can redistribute it and/or modify
5 * it under the terms of the MIT license. See LICENSE for details.
13 #include <stdlib.h> /* for size_t */
16 #include "jansson_config.h"
24 #define JANSSON_MAJOR_VERSION 2
25 #define JANSSON_MINOR_VERSION 11
26 #define JANSSON_MICRO_VERSION 0
28 /* Micro version is omitted if it's 0 */
29 #define JANSSON_VERSION "2.11"
31 /* Version as a 3-byte hex number, e.g. 0x010201 == 1.2.1. Use this
32 for numeric comparisons, e.g. #if JANSSON_VERSION_HEX >= ... */
33 #define JANSSON_VERSION_HEX ((JANSSON_MAJOR_VERSION << 16) | \
34 (JANSSON_MINOR_VERSION << 8) | \
35 (JANSSON_MICRO_VERSION << 0))
37 /* If __atomic or __sync builtins are available the library is thread
38 * safe for all read-only functions plus reference counting. */
39 #if JSON_HAVE_ATOMIC_BUILTINS || JSON_HAVE_SYNC_BUILTINS
40 #define JANSSON_THREAD_SAFE_REFCOUNT 1
56 typedef struct json_t
{
58 volatile size_t refcount
;
61 #ifndef JANSSON_USING_CMAKE /* disabled if using cmake */
62 #if JSON_INTEGER_IS_LONG_LONG
64 #define JSON_INTEGER_FORMAT "I64d"
66 #define JSON_INTEGER_FORMAT "lld"
68 typedef long long json_int_t
;
70 #define JSON_INTEGER_FORMAT "ld"
71 typedef long json_int_t
;
72 #endif /* JSON_INTEGER_IS_LONG_LONG */
75 #define json_typeof(json) ((json)->type)
76 #define json_is_object(json) ((json) && json_typeof(json) == JSON_OBJECT)
77 #define json_is_array(json) ((json) && json_typeof(json) == JSON_ARRAY)
78 #define json_is_string(json) ((json) && json_typeof(json) == JSON_STRING)
79 #define json_is_integer(json) ((json) && json_typeof(json) == JSON_INTEGER)
80 #define json_is_real(json) ((json) && json_typeof(json) == JSON_REAL)
81 #define json_is_number(json) (json_is_integer(json) || json_is_real(json))
82 #define json_is_true(json) ((json) && json_typeof(json) == JSON_TRUE)
83 #define json_is_false(json) ((json) && json_typeof(json) == JSON_FALSE)
84 #define json_boolean_value json_is_true
85 #define json_is_boolean(json) (json_is_true(json) || json_is_false(json))
86 #define json_is_null(json) ((json) && json_typeof(json) == JSON_NULL)
88 /* construction, destruction, reference counting */
90 json_t
*json_object(void);
91 json_t
*json_array(void);
92 json_t
*json_string(const char *value
);
93 json_t
*json_stringn(const char *value
, size_t len
);
94 json_t
*json_string_nocheck(const char *value
);
95 json_t
*json_stringn_nocheck(const char *value
, size_t len
);
96 json_t
*json_integer(json_int_t value
);
97 json_t
*json_real(double value
);
98 json_t
*json_true(void);
99 json_t
*json_false(void);
100 #define json_boolean(val) ((val) ? json_true() : json_false())
101 json_t
*json_null(void);
103 /* do not call JSON_INTERNAL_INCREF or JSON_INTERNAL_DECREF directly */
104 #if JSON_HAVE_ATOMIC_BUILTINS
105 #define JSON_INTERNAL_INCREF(json) __atomic_add_fetch(&json->refcount, 1, __ATOMIC_ACQUIRE)
106 #define JSON_INTERNAL_DECREF(json) __atomic_sub_fetch(&json->refcount, 1, __ATOMIC_RELEASE)
107 #elif JSON_HAVE_SYNC_BUILTINS
108 #define JSON_INTERNAL_INCREF(json) __sync_add_and_fetch(&json->refcount, 1)
109 #define JSON_INTERNAL_DECREF(json) __sync_sub_and_fetch(&json->refcount, 1)
111 #define JSON_INTERNAL_INCREF(json) (++json->refcount)
112 #define JSON_INTERNAL_DECREF(json) (--json->refcount)
116 json_t
*json_incref(json_t
*json
)
118 if(json
&& json
->refcount
!= (size_t)-1)
119 JSON_INTERNAL_INCREF(json
);
123 /* do not call json_delete directly */
124 void json_delete(json_t
*json
);
127 void json_decref(json_t
*json
)
129 if(json
&& json
->refcount
!= (size_t)-1 && JSON_INTERNAL_DECREF(json
) == 0)
133 #if defined(__GNUC__) || defined(__clang__)
135 void json_decrefp(json_t
**json
)
143 #define json_auto_t json_t __attribute__((cleanup(json_decrefp)))
147 /* error reporting */
149 #define JSON_ERROR_TEXT_LENGTH 160
150 #define JSON_ERROR_SOURCE_LENGTH 80
152 typedef struct json_error_t
{
156 char source
[JSON_ERROR_SOURCE_LENGTH
];
157 char text
[JSON_ERROR_TEXT_LENGTH
];
160 enum json_error_code
{
162 json_error_out_of_memory
,
163 json_error_stack_overflow
,
164 json_error_cannot_open_file
,
165 json_error_invalid_argument
,
166 json_error_invalid_utf8
,
167 json_error_premature_end_of_input
,
168 json_error_end_of_input_expected
,
169 json_error_invalid_syntax
,
170 json_error_invalid_format
,
171 json_error_wrong_type
,
172 json_error_null_character
,
173 json_error_null_value
,
174 json_error_null_byte_in_key
,
175 json_error_duplicate_key
,
176 json_error_numeric_overflow
,
177 json_error_item_not_found
,
178 json_error_index_out_of_range
181 static JSON_INLINE
enum json_error_code
json_error_code(const json_error_t
*e
) {
182 return (enum json_error_code
)e
->text
[JSON_ERROR_TEXT_LENGTH
- 1];
185 /* getters, setters, manipulation */
187 void json_object_seed(size_t seed
);
188 size_t json_object_size(const json_t
*object
);
189 json_t
*json_object_get(const json_t
*object
, const char *key
);
190 int json_object_set_new(json_t
*object
, const char *key
, json_t
*value
);
191 int json_object_set_new_nocheck(json_t
*object
, const char *key
, json_t
*value
);
192 int json_object_del(json_t
*object
, const char *key
);
193 int json_object_clear(json_t
*object
);
194 int json_object_update(json_t
*object
, json_t
*other
);
195 int json_object_update_existing(json_t
*object
, json_t
*other
);
196 int json_object_update_missing(json_t
*object
, json_t
*other
);
197 void *json_object_iter(json_t
*object
);
198 void *json_object_iter_at(json_t
*object
, const char *key
);
199 void *json_object_key_to_iter(const char *key
);
200 void *json_object_iter_next(json_t
*object
, void *iter
);
201 const char *json_object_iter_key(void *iter
);
202 json_t
*json_object_iter_value(void *iter
);
203 int json_object_iter_set_new(json_t
*object
, void *iter
, json_t
*value
);
205 #define json_object_foreach(object, key, value) \
206 for(key = json_object_iter_key(json_object_iter(object)); \
207 key && (value = json_object_iter_value(json_object_key_to_iter(key))); \
208 key = json_object_iter_key(json_object_iter_next(object, json_object_key_to_iter(key))))
210 #define json_object_foreach_safe(object, n, key, value) \
211 for(key = json_object_iter_key(json_object_iter(object)), \
212 n = json_object_iter_next(object, json_object_key_to_iter(key)); \
213 key && (value = json_object_iter_value(json_object_key_to_iter(key))); \
214 key = json_object_iter_key(n), \
215 n = json_object_iter_next(object, json_object_key_to_iter(key)))
217 #define json_array_foreach(array, index, value) \
219 index < json_array_size(array) && (value = json_array_get(array, index)); \
223 int json_object_set(json_t
*object
, const char *key
, json_t
*value
)
225 return json_object_set_new(object
, key
, json_incref(value
));
229 int json_object_set_nocheck(json_t
*object
, const char *key
, json_t
*value
)
231 return json_object_set_new_nocheck(object
, key
, json_incref(value
));
235 int json_object_iter_set(json_t
*object
, void *iter
, json_t
*value
)
237 return json_object_iter_set_new(object
, iter
, json_incref(value
));
240 size_t json_array_size(const json_t
*array
);
241 json_t
*json_array_get(const json_t
*array
, size_t index
);
242 int json_array_set_new(json_t
*array
, size_t index
, json_t
*value
);
243 int json_array_append_new(json_t
*array
, json_t
*value
);
244 int json_array_insert_new(json_t
*array
, size_t index
, json_t
*value
);
245 int json_array_remove(json_t
*array
, size_t index
);
246 int json_array_clear(json_t
*array
);
247 int json_array_extend(json_t
*array
, json_t
*other
);
250 int json_array_set(json_t
*array
, size_t ind
, json_t
*value
)
252 return json_array_set_new(array
, ind
, json_incref(value
));
256 int json_array_append(json_t
*array
, json_t
*value
)
258 return json_array_append_new(array
, json_incref(value
));
262 int json_array_insert(json_t
*array
, size_t ind
, json_t
*value
)
264 return json_array_insert_new(array
, ind
, json_incref(value
));
267 const char *json_string_value(const json_t
*string
);
268 size_t json_string_length(const json_t
*string
);
269 json_int_t
json_integer_value(const json_t
*integer
);
270 double json_real_value(const json_t
*real
);
271 double json_number_value(const json_t
*json
);
273 int json_string_set(json_t
*string
, const char *value
);
274 int json_string_setn(json_t
*string
, const char *value
, size_t len
);
275 int json_string_set_nocheck(json_t
*string
, const char *value
);
276 int json_string_setn_nocheck(json_t
*string
, const char *value
, size_t len
);
277 int json_integer_set(json_t
*integer
, json_int_t value
);
278 int json_real_set(json_t
*real
, double value
);
282 json_t
*json_pack(const char *fmt
, ...);
283 json_t
*json_pack_ex(json_error_t
*error
, size_t flags
, const char *fmt
, ...);
284 json_t
*json_vpack_ex(json_error_t
*error
, size_t flags
, const char *fmt
, va_list ap
);
286 #define JSON_VALIDATE_ONLY 0x1
287 #define JSON_STRICT 0x2
289 int json_unpack(json_t
*root
, const char *fmt
, ...);
290 int json_unpack_ex(json_t
*root
, json_error_t
*error
, size_t flags
, const char *fmt
, ...);
291 int json_vunpack_ex(json_t
*root
, json_error_t
*error
, size_t flags
, const char *fmt
, va_list ap
);
295 json_t
*json_sprintf(const char *fmt
, ...);
296 json_t
*json_vsprintf(const char *fmt
, va_list ap
);
301 int json_equal(const json_t
*value1
, const json_t
*value2
);
306 json_t
*json_copy(json_t
*value
);
307 json_t
*json_deep_copy(const json_t
*value
);
311 json_t
*json_path_get(const json_t
*json
, const char *path
);
312 int json_path_set_new(json_t
*json
, const char *path
, json_t
*value
, size_t flags
, json_error_t
*error
);
315 int json_path_set(json_t
*json
, const char *path
, json_t
*value
, size_t flags
, json_error_t
*error
)
317 return json_path_set_new(json
, path
, json_incref(value
), flags
, error
);
322 #define JSON_REJECT_DUPLICATES 0x1
323 #define JSON_DISABLE_EOF_CHECK 0x2
324 #define JSON_DECODE_ANY 0x4
325 #define JSON_DECODE_INT_AS_REAL 0x8
326 #define JSON_ALLOW_NUL 0x10
328 typedef size_t (*json_load_callback_t
)(void *buffer
, size_t buflen
, void *data
);
330 json_t
*json_loads(const char *input
, size_t flags
, json_error_t
*error
);
331 json_t
*json_loadb(const char *buffer
, size_t buflen
, size_t flags
, json_error_t
*error
);
332 json_t
*json_loadf(FILE *input
, size_t flags
, json_error_t
*error
);
333 json_t
*json_loadfd(int input
, size_t flags
, json_error_t
*error
);
334 json_t
*json_load_file(const char *path
, size_t flags
, json_error_t
*error
);
335 json_t
*json_load_callback(json_load_callback_t callback
, void *data
, size_t flags
, json_error_t
*error
);
340 #define JSON_MAX_INDENT 0x1F
341 #define JSON_INDENT(n) ((n) & JSON_MAX_INDENT)
342 #define JSON_COMPACT 0x20
343 #define JSON_ENSURE_ASCII 0x40
344 #define JSON_SORT_KEYS 0x80
345 #define JSON_PRESERVE_ORDER 0x100
346 #define JSON_ENCODE_ANY 0x200
347 #define JSON_ESCAPE_SLASH 0x400
348 #define JSON_REAL_PRECISION(n) (((n) & 0x1F) << 11)
349 #define JSON_EMBED 0x10000
351 typedef int (*json_dump_callback_t
)(const char *buffer
, size_t size
, void *data
);
353 char *json_dumps(const json_t
*json
, size_t flags
);
354 size_t json_dumpb(const json_t
*json
, char *buffer
, size_t size
, size_t flags
);
355 int json_dumpf(const json_t
*json
, FILE *output
, size_t flags
);
356 int json_dumpfd(const json_t
*json
, int output
, size_t flags
);
357 int json_dump_file(const json_t
*json
, const char *path
, size_t flags
);
358 int json_dump_callback(const json_t
*json
, json_dump_callback_t callback
, void *data
, size_t flags
);
360 /* custom memory allocation */
362 typedef void *(*json_malloc_t
)(size_t);
363 typedef void (*json_free_t
)(void *);
365 void json_set_alloc_funcs(json_malloc_t malloc_fn
, json_free_t free_fn
);
366 void json_get_alloc_funcs(json_malloc_t
*malloc_fn
, json_free_t
*free_fn
);