X-Git-Url: https://git.kernel.dk/?p=fio.git;a=blobdiff_plain;f=json.c;h=cd3d5d74db12aab06409e523b95d9eed3c013682;hp=cdc3b2185fa428e3a68842c44b7079448607108b;hb=c16dc793a3c45780f67ce65244b6e91323dee014;hpb=1e5324e723116a5faf9da686993cc79c14d62d4b diff --git a/json.c b/json.c index cdc3b218..cd3d5d74 100644 --- a/json.c +++ b/json.c @@ -1,6 +1,5 @@ #include #include -#include #include #include #include "json.h" @@ -8,18 +7,12 @@ struct json_object *json_create_object(void) { - struct json_object *obj = malloc(sizeof(struct json_object)); - if (obj) - memset(obj, 0, sizeof(struct json_object)); - return obj; + return calloc(1, sizeof(struct json_object)); } struct json_array *json_create_array(void) { - struct json_array *array = malloc(sizeof(struct json_array)); - if (array) - memset(array, 0, sizeof(struct json_array)); - return array; + return calloc(1, sizeof(struct json_array)); } static struct json_pair *json_create_pair(const char *name, struct json_value *value) @@ -35,7 +28,7 @@ static struct json_pair *json_create_pair(const char *name, struct json_value *v return pair; } -static struct json_value *json_create_value_int(long number) +static struct json_value *json_create_value_int(long long number) { struct json_value *value = malloc(sizeof(struct json_value)); @@ -46,7 +39,7 @@ static struct json_value *json_create_value_int(long number) return value; } -static struct json_value *json_create_value_float(float number) +static struct json_value *json_create_value_float(double number) { struct json_value *value = malloc(sizeof(struct json_value)); @@ -84,7 +77,7 @@ static char *strdup_escape(const char *str) } /* - * Valid JSON strings must escape '"' and '/' with a preceeding '/' + * Valid JSON strings must escape '"' and '/' with a preceding '/' */ static struct json_value *json_create_value_string(const char *str) { @@ -201,25 +194,31 @@ static int json_object_add_pair(struct json_object *obj, struct json_pair *pair) return 0; } -int json_object_add_value_type(struct json_object *obj, const char *name, int type, ...) +int json_object_add_value_type(struct json_object *obj, const char *name, + const struct json_value *arg) { struct json_value *value; struct json_pair *pair; - va_list args; int ret; - va_start(args, type); - if (type == JSON_TYPE_STRING) - value = json_create_value_string(va_arg(args, char *)); - else if (type == JSON_TYPE_INTEGER) - value = json_create_value_int(va_arg(args, long)); - else if (type == JSON_TYPE_FLOAT) - value = json_create_value_float(va_arg(args, double)); - else if (type == JSON_TYPE_OBJECT) - value = json_create_value_object(va_arg(args, struct json_object *)); - else - value = json_create_value_array(va_arg(args, struct json_array *)); - va_end(args); + switch (arg->type) { + case JSON_TYPE_STRING: + value = json_create_value_string(arg->string); + break; + case JSON_TYPE_INTEGER: + value = json_create_value_int(arg->integer_number); + break; + case JSON_TYPE_FLOAT: + value = json_create_value_float(arg->float_number); + break; + case JSON_TYPE_OBJECT: + value = json_create_value_object(arg->object); + break; + default: + case JSON_TYPE_ARRAY: + value = json_create_value_array(arg->array); + break; + } if (!value) return ENOMEM; @@ -237,25 +236,30 @@ int json_object_add_value_type(struct json_object *obj, const char *name, int ty return 0; } -static void json_print_array(struct json_array *array); -int json_array_add_value_type(struct json_array *array, int type, ...) +int json_array_add_value_type(struct json_array *array, + const struct json_value *arg) { struct json_value *value; - va_list args; int ret; - va_start(args, type); - if (type == JSON_TYPE_STRING) - value = json_create_value_string(va_arg(args, char *)); - else if (type == JSON_TYPE_INTEGER) - value = json_create_value_int(va_arg(args, long)); - else if (type == JSON_TYPE_FLOAT) - value = json_create_value_float(va_arg(args, double)); - else if (type == JSON_TYPE_OBJECT) - value = json_create_value_object(va_arg(args, struct json_object *)); - else - value = json_create_value_array(va_arg(args, struct json_array *)); - va_end(args); + switch (arg->type) { + case JSON_TYPE_STRING: + value = json_create_value_string(arg->string); + break; + case JSON_TYPE_INTEGER: + value = json_create_value_int(arg->integer_number); + break; + case JSON_TYPE_FLOAT: + value = json_create_value_float(arg->float_number); + break; + case JSON_TYPE_OBJECT: + value = json_create_value_object(arg->object); + break; + default: + case JSON_TYPE_ARRAY: + value = json_create_value_array(arg->array); + break; + } if (!value) return ENOMEM; @@ -296,70 +300,70 @@ static int json_value_level(struct json_value *value) return json_array_level(value->parent_array) + 1; } -static void json_print_level(int level) +static void json_print_level(int level, struct buf_output *out) { while (level-- > 0) - log_info(" "); + log_buf(out, " "); } -static void json_print_pair(struct json_pair *pair); -static void json_print_array(struct json_array *array); -static void json_print_value(struct json_value *value); -void json_print_object(struct json_object *obj) +static void json_print_pair(struct json_pair *pair, struct buf_output *); +static void json_print_value(struct json_value *value, struct buf_output *); + +void json_print_object(struct json_object *obj, struct buf_output *out) { int i; - log_info("{\n"); + log_buf(out, "{\n"); for (i = 0; i < obj->pair_cnt; i++) { if (i > 0) - log_info(",\n"); - json_print_pair(obj->pairs[i]); + log_buf(out, ",\n"); + json_print_pair(obj->pairs[i], out); } - log_info("\n"); - json_print_level(json_object_level(obj)); - log_info("}"); + log_buf(out, "\n"); + json_print_level(json_object_level(obj), out); + log_buf(out, "}"); } -static void json_print_pair(struct json_pair *pair) +static void json_print_pair(struct json_pair *pair, struct buf_output *out) { - json_print_level(json_pair_level(pair)); - log_info("\"%s\" : ", pair->name); - json_print_value(pair->value); + json_print_level(json_pair_level(pair), out); + log_buf(out, "\"%s\" : ", pair->name); + json_print_value(pair->value, out); } -static void json_print_array(struct json_array *array) +static void json_print_array(struct json_array *array, struct buf_output *out) { int i; - log_info("[\n"); + log_buf(out, "[\n"); for (i = 0; i < array->value_cnt; i++) { if (i > 0) - log_info(",\n"); - json_print_level(json_value_level(array->values[i])); - json_print_value(array->values[i]); + log_buf(out, ",\n"); + json_print_level(json_value_level(array->values[i]), out); + json_print_value(array->values[i], out); } - log_info("\n"); - json_print_level(json_array_level(array)); - log_info("]"); + log_buf(out, "\n"); + json_print_level(json_array_level(array), out); + log_buf(out, "]"); } -static void json_print_value(struct json_value *value) +static void json_print_value(struct json_value *value, struct buf_output *out) { switch (value->type) { case JSON_TYPE_STRING: - log_info("\"%s\"", value->string); + log_buf(out, "\"%s\"", value->string); break; case JSON_TYPE_INTEGER: - log_info("%ld", value->integer_number); + log_buf(out, "%lld", value->integer_number); break; case JSON_TYPE_FLOAT: - log_info("%.2f", value->float_number); + log_buf(out, "%f", value->float_number); break; case JSON_TYPE_OBJECT: - json_print_object(value->object); + json_print_object(value->object, out); break; case JSON_TYPE_ARRAY: - json_print_array(value->array); + json_print_array(value->array, out); break; } }