From 738a9914a066a31750925543a8c6d2661bd61345 Mon Sep 17 00:00:00 2001 From: Siddhesh Poyarekar Date: Thu, 22 Jun 2017 23:44:12 +0530 Subject: benchtests: Print string array elements, int and uint in json Enhance the json module in benchtests to print signed and unsigned integers and string array elements. * benchtests/json-lib.h: Include inttypes.h. (json_attr_int, json_attr_int, json_element_string, json_element_int, json_element_uint): New functions. * benchtests/json-lib.c: (json_attr_int, json_attr_int, json_element_string, json_element_int, json_element_uint): New functions. --- benchtests/json-lib.c | 62 +++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 62 insertions(+) (limited to 'benchtests/json-lib.c') diff --git a/benchtests/json-lib.c b/benchtests/json-lib.c index 61573c579a..9743506c00 100644 --- a/benchtests/json-lib.c +++ b/benchtests/json-lib.c @@ -100,6 +100,32 @@ json_attr_string (json_ctx_t *ctx, const char *name, const char *s) fprintf (ctx->fp, "\"%s\": \"%s\"", name, s); } +void +json_attr_uint (json_ctx_t *ctx, const char *name, uint64_t d) +{ + if (!ctx->first_element) + fprintf (ctx->fp, ",\n"); + else + ctx->first_element = false; + + do_indent (ctx); + + fprintf (ctx->fp, "\"%s\": %" PRIu64 , name, d); +} + +void +json_attr_int (json_ctx_t *ctx, const char *name, int64_t d) +{ + if (!ctx->first_element) + fprintf (ctx->fp, ",\n"); + else + ctx->first_element = false; + + do_indent (ctx); + + fprintf (ctx->fp, "\"%s\": %" PRId64 , name, d); +} + void json_attr_double (json_ctx_t *ctx, const char *name, double d) { @@ -136,6 +162,42 @@ json_array_end (json_ctx_t *ctx) fputs ("]", ctx->fp); } +void +json_element_string (json_ctx_t *ctx, const char *s) +{ + if (!ctx->first_element) + fprintf (ctx->fp, ", \"%s\"", s); + else + { + fprintf (ctx->fp, "\"%s\"", s); + ctx->first_element = false; + } +} + +void +json_element_uint (json_ctx_t *ctx, uint64_t d) +{ + if (!ctx->first_element) + fprintf (ctx->fp, ", %" PRIu64, d); + else + { + fprintf (ctx->fp, "%" PRIu64, d); + ctx->first_element = false; + } +} + +void +json_element_int (json_ctx_t *ctx, int64_t d) +{ + if (!ctx->first_element) + fprintf (ctx->fp, ", %" PRId64, d); + else + { + fprintf (ctx->fp, "%" PRId64, d); + ctx->first_element = false; + } +} + void json_element_double (json_ctx_t *ctx, double d) { -- cgit v1.2.3