X-Git-Url: http://www.project-moonshot.org/gitweb/?a=blobdiff_plain;f=src%2Fjansson.h;h=0f1de8d8077b39d5cd6eced037986683db9c93cb;hb=198d537be76ae4debaac7f730bb2c591b04ab1df;hp=81235ff4069a81cbedd94b11f74139cdb6c5a15b;hpb=7ce70533c90dc7dfc3570023144547dfb32950e1;p=jansson.git diff --git a/src/jansson.h b/src/jansson.h index 81235ff..0f1de8d 100644 --- a/src/jansson.h +++ b/src/jansson.h @@ -34,6 +34,14 @@ typedef struct { size_t refcount; } json_t; +#if JSON_INTEGER_IS_LONG_LONG +#define JSON_INTEGER_FORMAT "lld" +typedef long long json_int_t; +#else +#define JSON_INTEGER_FORMAT "ld" +typedef long json_int_t; +#endif /* JSON_INTEGER_IS_LONG_LONG */ + #define json_typeof(json) ((json)->type) #define json_is_object(json) (json && json_typeof(json) == JSON_OBJECT) #define json_is_array(json) (json && json_typeof(json) == JSON_ARRAY) @@ -52,7 +60,7 @@ json_t *json_object(void); json_t *json_array(void); json_t *json_string(const char *value); json_t *json_string_nocheck(const char *value); -json_t *json_integer(long value); +json_t *json_integer(json_int_t value); json_t *json_real(double value); json_t *json_true(void); json_t *json_false(void); @@ -77,6 +85,14 @@ void json_decref(json_t *json) } +/* error reporting */ + +typedef struct json_error_t json_error_t; + +const char *json_error_msg(const json_error_t *error); +int json_error_line(const json_error_t *error); + + /* getters, setters, manipulation */ size_t json_object_size(const json_t *object); @@ -105,7 +121,7 @@ int json_object_set_nocheck(json_t *object, const char *key, json_t *value) return json_object_set_new_nocheck(object, key, json_incref(value)); } -static inline +static JSON_INLINE int json_object_iter_set(json_t *object, void *iter, json_t *value) { return json_object_iter_set_new(object, iter, json_incref(value)); @@ -139,15 +155,17 @@ int json_array_insert(json_t *array, size_t index, json_t *value) } const char *json_string_value(const json_t *string); -long json_integer_value(const json_t *integer); +json_int_t json_integer_value(const json_t *integer); double json_real_value(const json_t *real); double json_number_value(const json_t *json); int json_string_set(json_t *string, const char *value); int json_string_set_nocheck(json_t *string, const char *value); -int json_integer_set(json_t *integer, long value); +int json_integer_set(json_t *integer, json_int_t value); int json_real_set(json_t *real, double value); +json_t *json_pack(json_error_t **error, const char *fmt, ...); +int json_unpack(json_t *root, json_error_t **error, const char *fmt, ...); /* equality */ @@ -162,22 +180,15 @@ json_t *json_deep_copy(json_t *value); /* loading, printing */ -#define JSON_ERROR_TEXT_LENGTH 160 +json_t *json_loads(const char *input, size_t flags, json_error_t **error); +json_t *json_loadf(FILE *input, size_t flags, json_error_t **error); +json_t *json_load_file(const char *path, size_t flags, json_error_t **error); -typedef struct { - char text[JSON_ERROR_TEXT_LENGTH]; - int line; -} json_error_t; - -json_t *json_loads(const char *input, json_error_t *error); -json_t *json_loadf(FILE *input, json_error_t *error); -json_t *json_load_file(const char *path, json_error_t *error); - -#define JSON_INDENT(n) (n & 0xFF) -#define JSON_COMPACT 0x100 -#define JSON_ENSURE_ASCII 0x200 -#define JSON_SORT_KEYS 0x400 -#define JSON_PRESERVE_ORDER 0x800 +#define JSON_INDENT(n) (n & 0x1F) +#define JSON_COMPACT 0x20 +#define JSON_ENSURE_ASCII 0x40 +#define JSON_SORT_KEYS 0x80 +#define JSON_PRESERVE_ORDER 0x100 char *json_dumps(const json_t *json, size_t flags); int json_dumpf(const json_t *json, FILE *output, size_t flags);