From f6f66c90215180654cedf1c900560944a5ecef9b Mon Sep 17 00:00:00 2001 From: Přemysl Janouch Date: Sun, 22 Feb 2015 21:30:30 +0100 Subject: Fix a leak and a null pointer dereference --- json-rpc-shell.c | 15 ++++++++++----- 1 file changed, 10 insertions(+), 5 deletions(-) (limited to 'json-rpc-shell.c') diff --git a/json-rpc-shell.c b/json-rpc-shell.c index 6e8a4f6..2dfd4ed 100644 --- a/json-rpc-shell.c +++ b/json-rpc-shell.c @@ -169,16 +169,19 @@ vprint_attributed (struct app_context *ctx, if (!attribute) printer = NULL; - const char *value; - value = str_map_find (&ctx->config, attribute); - if (printer && soft_assert (value)) + if (printer) + { + const char *value = str_map_find (&ctx->config, attribute); tputs (value, 1, printer); + } vfprintf (stream, fmt, ap); - value = str_map_find (&ctx->config, ATTR_RESET); - if (printer && soft_assert (value)) + if (printer) + { + const char *value = str_map_find (&ctx->config, ATTR_RESET); tputs (value, 1, printer); + } } static void @@ -465,6 +468,8 @@ parse_response (struct app_context *ctx, struct str *buf) char *utf8 = xstrdup_printf ("error response: %" JSON_INTEGER_FORMAT " (%s)", code_val, json_string_value (message)); char *s = iconv_xstrdup (ctx->term_from_utf8, utf8, -1, NULL); + free (utf8); + if (!s) print_error ("character conversion failed for `%s'", "error"); else -- cgit v1.2.3-70-g09d2