mirror of
https://github.com/json-c/json-c.git
synced 2026-04-04 12:59:07 +08:00
The split of json_object into type-specific sub-structures is now functionally complete.
Remove all of the temporary defines, structures, old compat fuctions, extra fields, etc... that were needed during the conversion to a split set of json_object_* structures.
This commit is contained in:
474
json_object.c
474
json_object.c
File diff suppressed because it is too large
Load Diff
@@ -490,9 +490,8 @@ JSON_EXPORT void json_object_object_del(struct json_object *obj, const char *key
|
|||||||
* @param obj the json_object instance
|
* @param obj the json_object instance
|
||||||
* @param iter the object iterator, use type json_object_iter
|
* @param iter the object iterator, use type json_object_iter
|
||||||
*/
|
*/
|
||||||
// XAX temporary workaround during code conversion:
|
|
||||||
#define json_object_object_foreachC(obj, iter) \
|
#define json_object_object_foreachC(obj, iter) \
|
||||||
for (iter.entry = json_object_get_object(PUBLIC(obj))->head; \
|
for (iter.entry = json_object_get_object(obj)->head; \
|
||||||
(iter.entry ? (iter.key = (char *)lh_entry_k(iter.entry), \
|
(iter.entry ? (iter.key = (char *)lh_entry_k(iter.entry), \
|
||||||
iter.val = (struct json_object *)lh_entry_v(iter.entry), iter.entry) \
|
iter.val = (struct json_object *)lh_entry_v(iter.entry), iter.entry) \
|
||||||
: 0); \
|
: 0); \
|
||||||
|
|||||||
@@ -20,14 +20,11 @@
|
|||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/**< how many bytes are directly stored in json_object for strings? */
|
|
||||||
#define LEN_DIRECT_STRING_DATA 32
|
|
||||||
|
|
||||||
struct json_object;
|
struct json_object;
|
||||||
#include "json_inttypes.h"
|
#include "json_inttypes.h"
|
||||||
#include "json_types.h"
|
#include "json_types.h"
|
||||||
|
|
||||||
typedef void(json_object_private_delete_fn)(struct json_object *o);
|
typedef void (json_object_private_delete_fn)(struct json_object *o);
|
||||||
|
|
||||||
/* json object int type, support extension*/
|
/* json object int type, support extension*/
|
||||||
typedef enum json_object_int_type
|
typedef enum json_object_int_type
|
||||||
@@ -36,9 +33,8 @@ typedef enum json_object_int_type
|
|||||||
json_object_int_type_uint64
|
json_object_int_type_uint64
|
||||||
} json_object_int_type;
|
} json_object_int_type;
|
||||||
|
|
||||||
struct json_object_base // XAX rename to json_object after conversion
|
struct json_object
|
||||||
{
|
{
|
||||||
int newold; // XAX temporary, remove after code conversion
|
|
||||||
enum json_type o_type;
|
enum json_type o_type;
|
||||||
uint32_t _ref_count;
|
uint32_t _ref_count;
|
||||||
json_object_private_delete_fn *_delete;
|
json_object_private_delete_fn *_delete;
|
||||||
@@ -51,28 +47,28 @@ struct json_object_base // XAX rename to json_object after conversion
|
|||||||
|
|
||||||
struct json_object_object
|
struct json_object_object
|
||||||
{
|
{
|
||||||
struct json_object_base base;
|
struct json_object base;
|
||||||
struct lh_table *c_object;
|
struct lh_table *c_object;
|
||||||
};
|
};
|
||||||
struct json_object_array
|
struct json_object_array
|
||||||
{
|
{
|
||||||
struct json_object_base base;
|
struct json_object base;
|
||||||
struct array_list *c_array;
|
struct array_list *c_array;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct json_object_boolean
|
struct json_object_boolean
|
||||||
{
|
{
|
||||||
struct json_object_base base;
|
struct json_object base;
|
||||||
json_bool c_boolean;
|
json_bool c_boolean;
|
||||||
};
|
};
|
||||||
struct json_object_double
|
struct json_object_double
|
||||||
{
|
{
|
||||||
struct json_object_base base;
|
struct json_object base;
|
||||||
double c_double;
|
double c_double;
|
||||||
};
|
};
|
||||||
struct json_object_int
|
struct json_object_int
|
||||||
{
|
{
|
||||||
struct json_object_base base;
|
struct json_object base;
|
||||||
enum json_object_int_type cint_type;
|
enum json_object_int_type cint_type;
|
||||||
union
|
union
|
||||||
{
|
{
|
||||||
@@ -82,7 +78,7 @@ struct json_object_int
|
|||||||
};
|
};
|
||||||
struct json_object_string
|
struct json_object_string
|
||||||
{
|
{
|
||||||
struct json_object_base base;
|
struct json_object base;
|
||||||
ssize_t len; // Signed b/c negative lengths indicate data is a pointer
|
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
|
// Consider adding an "alloc" field here, if json_object_set_string calls
|
||||||
// to expand the length of a string are common operations to perform.
|
// to expand the length of a string are common operations to perform.
|
||||||
@@ -93,21 +89,6 @@ struct json_object_string
|
|||||||
} c_string;
|
} 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, ...);
|
void _json_c_set_last_err(const char *err_fmt, ...);
|
||||||
|
|
||||||
extern const char *json_number_chars;
|
extern const char *json_number_chars;
|
||||||
|
|||||||
@@ -20,7 +20,7 @@ int main()
|
|||||||
printf("obj.to_string(standard)=%s\n", json_object_to_json_string(obj));
|
printf("obj.to_string(standard)=%s\n", json_object_to_json_string(obj));
|
||||||
|
|
||||||
printf("Test default serializer with custom userdata:\n");
|
printf("Test default serializer with custom userdata:\n");
|
||||||
((struct json_object_base *)obj)->_userdata = udata;
|
((struct json_object *)obj)->_userdata = udata;
|
||||||
printf("obj.to_string(userdata)=%s\n", json_object_to_json_string(obj));
|
printf("obj.to_string(userdata)=%s\n", json_object_to_json_string(obj));
|
||||||
|
|
||||||
printf("Test explicit serializer with custom userdata:\n");
|
printf("Test explicit serializer with custom userdata:\n");
|
||||||
|
|||||||
@@ -56,12 +56,12 @@ int main(int argc, char **argv)
|
|||||||
#define MID "A MID STRING"
|
#define MID "A MID STRING"
|
||||||
// 12345678901234567890123456789012....
|
// 12345678901234567890123456789012....
|
||||||
#define HUGE "A string longer than 32 chars as to check non local buf codepath"
|
#define HUGE "A string longer than 32 chars as to check non local buf codepath"
|
||||||
tmp = json_object_new_string(SHORT);
|
tmp = json_object_new_string(MID);
|
||||||
assert(strcmp(json_object_get_string(tmp), SHORT) == 0);
|
|
||||||
assert(strcmp(json_object_to_json_string(tmp), "\"" SHORT "\"") == 0);
|
|
||||||
json_object_set_string(tmp, MID);
|
|
||||||
assert(strcmp(json_object_get_string(tmp), MID) == 0);
|
assert(strcmp(json_object_get_string(tmp), MID) == 0);
|
||||||
assert(strcmp(json_object_to_json_string(tmp), "\"" MID "\"") == 0);
|
assert(strcmp(json_object_to_json_string(tmp), "\"" MID "\"") == 0);
|
||||||
|
json_object_set_string(tmp, SHORT);
|
||||||
|
assert(strcmp(json_object_get_string(tmp), SHORT) == 0);
|
||||||
|
assert(strcmp(json_object_to_json_string(tmp), "\"" SHORT "\"") == 0);
|
||||||
json_object_set_string(tmp, HUGE);
|
json_object_set_string(tmp, HUGE);
|
||||||
assert(strcmp(json_object_get_string(tmp), HUGE) == 0);
|
assert(strcmp(json_object_get_string(tmp), HUGE) == 0);
|
||||||
assert(strcmp(json_object_to_json_string(tmp), "\"" HUGE "\"") == 0);
|
assert(strcmp(json_object_to_json_string(tmp), "\"" HUGE "\"") == 0);
|
||||||
|
|||||||
Reference in New Issue
Block a user