From ac614014cf7e9aa8edd0367ca357266afd500f90 Mon Sep 17 00:00:00 2001 From: Shahram Najm Date: Wed, 24 Oct 2018 16:31:45 +0100 Subject: [PATCH] ECC-767: grib_dump -j produces invalid JSON when a file has multiple messages --- tools/grib_dump.c | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) diff --git a/tools/grib_dump.c b/tools/grib_dump.c index d364275fd..961392f89 100644 --- a/tools/grib_dump.c +++ b/tools/grib_dump.c @@ -41,6 +41,7 @@ const char* grib_tool_description="Dump the content of a GRIB file in different const char* grib_tool_name="grib_dump"; const char* grib_tool_usage="[options] grib_file grib_file ..."; static int json=0; +static int first_handle=1; int grib_options_count=sizeof(grib_options)/sizeof(grib_option); @@ -176,6 +177,13 @@ int grib_tool_new_handle_action(grib_runtime_options* options, grib_handle* h) grib_set_flag(h,options->print_keys[i].name,GRIB_ACCESSOR_FLAG_DUMP); if(json) { + if (!first_handle && options->handle_count>1) { + fprintf(stdout,",\n"); + } + if (json && first_handle) { + fprintf(stdout,"{ \"messages\" : [\n"); + first_handle=0; + } } else { char tmp[1024]; @@ -210,11 +218,21 @@ void grib_tool_print_key_values(grib_runtime_options* options,grib_handle* h) int grib_tool_finalise_action(grib_runtime_options* options) { + if (json) fprintf(stdout,"\n]}\n"); return 0; } int grib_no_handle_action(grib_runtime_options* options, int err) { + if (json ){ + if (first_handle) { + fprintf(dump_file,"{ \"messages\" : [ \n"); + first_handle=0; + } else { + fprintf(dump_file,",\n"); + } + } + fprintf(dump_file,"\t\t\"ERROR: unreadable message\"\n"); return 0; }