From 1a4f355a7bc268376dcad4f81df0b67acf68d772 Mon Sep 17 00:00:00 2001 From: Mark Beckwith <wythe@intrig.com> Date: Sat, 15 Sep 2018 12:12:15 -0500 Subject: [PATCH] param: add ok flag to struct command Callers to param() can now optionally set a flag to see if command_fail was called. This is necessary because the `cmd` is freed in case of failure. I spent a bit of time trying to extend the lifetime of the `cmd` to the end of parse_request(), but the destructors still needed to be called when they were, and it was getting ugly. So I took this minimal approach. Signed-off-by: Mark Beckwith <wythe@intrig.com> --- lightningd/jsonrpc.c | 6 ++++++ lightningd/jsonrpc.h | 1 + 2 files changed, 7 insertions(+) diff --git a/lightningd/jsonrpc.c b/lightningd/jsonrpc.c index a7f78a8bd..39223f761 100644 --- a/lightningd/jsonrpc.c +++ b/lightningd/jsonrpc.c @@ -282,6 +282,8 @@ static void connection_complete_ok(struct json_connection *jcon, { assert(id != NULL); assert(result != NULL); + if (cmd->ok) + *(cmd->ok) = true; /* This JSON is simple enough that we build manually */ json_done(jcon, cmd, take(tal_fmt(jcon, @@ -310,6 +312,9 @@ static void connection_complete_error(struct json_connection *jcon, assert(id != NULL); + if (cmd->ok) + *(cmd->ok) = false; + json_done(jcon, cmd, take(tal_fmt(tmpctx, "{ \"jsonrpc\": \"2.0\", " " \"error\" : " @@ -452,6 +457,7 @@ static void parse_request(struct json_connection *jcon, const jsmntok_t tok[]) json_tok_contents(jcon->buffer, id), json_tok_len(id)); c->mode = CMD_NORMAL; + c->ok = NULL; list_add(&jcon->commands, &c->list); tal_add_destructor(c, destroy_cmd); diff --git a/lightningd/jsonrpc.h b/lightningd/jsonrpc.h index e155258a2..c85cf0928 100644 --- a/lightningd/jsonrpc.h +++ b/lightningd/jsonrpc.h @@ -37,6 +37,7 @@ struct command { enum command_mode mode; /* This is created if mode is CMD_USAGE */ const char *usage; + bool *ok; }; struct json_connection {