diff options
| author | Přemysl Janouch <p.janouch@gmail.com> | 2014-09-07 03:04:22 +0200 | 
|---|---|---|
| committer | Přemysl Janouch <p.janouch@gmail.com> | 2014-09-08 20:53:46 +0200 | 
| commit | 0cbcf609923f9e05195705835650c4cc9a96b80d (patch) | |
| tree | b79a2b37c3e91a69278ad0d77d9776b41fd57216 | |
| parent | 8824903ae286dae28cf6f2ddc0f488e670bd5b51 (diff) | |
| download | json-rpc-shell-0cbcf609923f9e05195705835650c4cc9a96b80d.tar.gz json-rpc-shell-0cbcf609923f9e05195705835650c4cc9a96b80d.tar.xz json-rpc-shell-0cbcf609923f9e05195705835650c4cc9a96b80d.zip | |
Avoid a resource leak
| -rw-r--r-- | json-rpc-shell.c | 22 | 
1 files changed, 15 insertions, 7 deletions
| diff --git a/json-rpc-shell.c b/json-rpc-shell.c index 554d91d..b880038 100644 --- a/json-rpc-shell.c +++ b/json-rpc-shell.c @@ -501,7 +501,7 @@ process_input (struct app_context *ctx, char *user_input)  	// Now we go through this madness, just so that the order can be arbitrary  	json_error_t e;  	size_t args_len = 0; -	json_t *args[2], *id = NULL, *params = NULL; +	json_t *args[2] = { NULL, NULL }, *id = NULL, *params = NULL;  	while (true)  	{ @@ -514,13 +514,13 @@ process_input (struct app_context *ctx, char *user_input)  		if (args_len == N_ELEMENTS (args))  		{  			print_error ("too many arguments"); -			goto fail_tokener; +			goto fail_parse;  		}  		if (!(args[args_len] = json_loadb (p, len - (p - input),  			JSON_DECODE_ANY | JSON_DISABLE_EOF_CHECK, &e)))  		{  			print_error ("failed to parse JSON value: %s", e.text); -			goto fail_tokener; +			goto fail_parse;  		}  		p += e.position;  		args_len++; @@ -528,15 +528,23 @@ process_input (struct app_context *ctx, char *user_input)  	for (size_t i = 0; i < args_len; i++)  	{ +		json_t **target;  		if (is_valid_json_rpc_id (args[i])) -			id = json_incref (args[i]); +			target = &id;  		else if (is_valid_json_rpc_params (args[i])) -			params = json_incref (args[i]); +			target = ¶ms;  		else  		{  			print_error ("unexpected value at index %zu", i); -			goto fail_tokener; +			goto fail_parse;  		} + +		if (*target) +		{ +			print_error ("cannot specify multiple `id' or `params'"); +			goto fail_parse; +		} +		*target = json_incref (args[i]);  	}  	if (!id && ctx->auto_id) @@ -544,7 +552,7 @@ process_input (struct app_context *ctx, char *user_input)  	make_json_rpc_call (ctx, method, id, params); -fail_tokener: +fail_parse:  	if (id)      json_decref (id);  	if (params)  json_decref (params); | 
