|
- /*
- * $Id: json_object_private.h,v 1.4 2006/01/26 02:16:28 mclark Exp $
- *
- * Copyright (c) 2004, 2005 Metaparadigm Pte. Ltd.
- * Michael Clark <michael@metaparadigm.com>
- *
- * This library is free software; you can redistribute it and/or modify
- * it under the terms of the MIT license. See COPYING for details.
- *
- */
-
- /**
- * @file
- * @brief Do not use, json-c internal, may be changed or removed at any time.
- */
- #ifndef _json_object_private_h_
- #define _json_object_private_h_
-
- #ifdef __cplusplus
- extern "C" {
- #endif
-
- /**< how many bytes are directly stored in json_object for strings? */
- #define LEN_DIRECT_STRING_DATA 32
-
- struct json_object;
- #include "json_inttypes.h"
- #include "json_types.h"
-
- typedef void(json_object_private_delete_fn)(struct json_object *o);
-
- /* json object int type, support extension*/
- typedef enum json_object_int_type
- {
- json_object_int_type_int64,
- json_object_int_type_uint64
- } json_object_int_type;
-
- struct json_object_base // XAX rename to json_object after conversion
- {
- int newold; // XAX temporary, remove after code conversion
- enum json_type o_type;
- uint32_t _ref_count;
- json_object_private_delete_fn *_delete;
- json_object_to_json_string_fn *_to_json_string;
- struct printbuf *_pb;
- json_object_delete_fn *_user_delete;
- void *_userdata;
- char data[1]; // Actually the rest of a struct json_object_${o_type}
- };
-
- struct json_object_object
- {
- struct json_object_base base;
- struct lh_table *c_object;
- };
- struct json_object_array
- {
- struct json_object_base base;
- struct array_list *c_array;
- };
-
- struct json_object_boolean
- {
- struct json_object_base base;
- json_bool c_boolean;
- };
- struct json_object_double
- {
- struct json_object_base base;
- double c_double;
- };
- struct json_object_int
- {
- struct json_object_base base;
- enum json_object_int_type cint_type;
- union
- {
- int64_t c_int64;
- uint64_t c_uint64;
- } cint;
- };
- struct json_object_string
- {
- struct json_object_base base;
- ssize_t len; // Signed b/c negative lengths indicate data is a pointer
- // Consider adding an "alloc" field here, if json_object_set_string calls
- // to expand the length of a string are common operations to perform.
- union
- {
- char idata[1]; // Immediate data. Actually longer
- char *pdata; // Only when len < 0
- } c_string;
- };
-
- struct json_object
- {
- int newold;
- enum json_type o_type;
- uint32_t _ref_count;
- json_object_private_delete_fn *_delete;
- json_object_to_json_string_fn *_to_json_string;
- struct printbuf *_pb;
- int dummyval; // XAX temp spacer to catch casting errors
- int du1mmyval; // XAX spacer
- int d2ummyval; // XAX spacer
- json_object_delete_fn *_user_delete;
- void *_userdata;
- };
-
- void _json_c_set_last_err(const char *err_fmt, ...);
-
- extern const char *json_number_chars;
- extern const char *json_hex_chars;
-
- #ifdef __cplusplus
- }
- #endif
-
- #endif
|