From 122a1e2af99280d9112c92c26040f6bccd29fec3 Mon Sep 17 00:00:00 2001 From: "Ian T. Jacobsen" Date: Wed, 16 Jul 2014 00:16:32 +0100 Subject: [PATCH 1/2] Fixed cases where file would be opened, but not closed. And small realloc memory issue. --- test/bin/json_process.c | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/test/bin/json_process.c b/test/bin/json_process.c index 7ae1d06..1d0afcc 100644 --- a/test/bin/json_process.c +++ b/test/bin/json_process.c @@ -181,6 +181,7 @@ int use_conf(char *test_path) if (conf.indent < 0 || conf.indent > 31) { fprintf(stderr, "invalid value for JSON_INDENT: %d\n", conf.indent); + fclose(infile); return 2; } if (conf.indent) @@ -201,6 +202,7 @@ int use_conf(char *test_path) if (conf.precision < 0 || conf.precision > 31) { fprintf(stderr, "invalid value for JSON_REAL_PRECISION: %d\n", conf.precision); + fclose(infile); return 2; } if (conf.precision) @@ -303,17 +305,19 @@ int use_env() if(getenv_int("STRIP")) { /* Load to memory, strip leading and trailing whitespace */ size_t size = 0, used = 0; - char *buffer = NULL; + char *buffer = NULL, *buf_ck = NULL; while(1) { size_t count; size = (size == 0 ? 128 : size * 2); - buffer = realloc(buffer, size); - if(!buffer) { + buf_ck = realloc(buffer, size); + if(!buf_ck) { fprintf(stderr, "Unable to allocate %d bytes\n", (int)size); + free(buffer); return 1; } + buffer = buf_ck; count = fread(buffer + used, 1, size - used, stdin); if(count < size - used) { From 4f1238af71d26346b31b1c9cee3d38a2ccf6bcca Mon Sep 17 00:00:00 2001 From: "Ian T. Jacobsen" Date: Wed, 16 Jul 2014 00:21:16 +0100 Subject: [PATCH 2/2] Fix whitespace issues --- test/bin/json_process.c | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/test/bin/json_process.c b/test/bin/json_process.c index 1d0afcc..bbb7da8 100644 --- a/test/bin/json_process.c +++ b/test/bin/json_process.c @@ -181,7 +181,7 @@ int use_conf(char *test_path) if (conf.indent < 0 || conf.indent > 31) { fprintf(stderr, "invalid value for JSON_INDENT: %d\n", conf.indent); - fclose(infile); + fclose(infile); return 2; } if (conf.indent) @@ -202,7 +202,7 @@ int use_conf(char *test_path) if (conf.precision < 0 || conf.precision > 31) { fprintf(stderr, "invalid value for JSON_REAL_PRECISION: %d\n", conf.precision); - fclose(infile); + fclose(infile); return 2; } if (conf.precision) @@ -314,10 +314,10 @@ int use_env() buf_ck = realloc(buffer, size); if(!buf_ck) { fprintf(stderr, "Unable to allocate %d bytes\n", (int)size); - free(buffer); + free(buffer); return 1; } - buffer = buf_ck; + buffer = buf_ck; count = fread(buffer + used, 1, size - used, stdin); if(count < size - used) {