diff options
author | nicm <nicm> | 2020-03-21 13:15:38 +0000 |
---|---|---|
committer | nicm <nicm> | 2020-03-21 13:15:38 +0000 |
commit | 5aeab5ab4075c7740c223678df1548dc4a402d83 (patch) | |
tree | c39c53fad7f2de1f3d001f7482272f24e826c696 | |
parent | 9a55f65702b5d32e0127c78ea9762c7bb47e3477 (diff) | |
download | rtmux-5aeab5ab4075c7740c223678df1548dc4a402d83.tar.gz rtmux-5aeab5ab4075c7740c223678df1548dc4a402d83.tar.bz2 rtmux-5aeab5ab4075c7740c223678df1548dc4a402d83.zip |
Preserve exit status from run-shell and pass to the client.
-rw-r--r-- | cmd-run-shell.c | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/cmd-run-shell.c b/cmd-run-shell.c index 1cf97d51..a57beb83 100644 --- a/cmd-run-shell.c +++ b/cmd-run-shell.c @@ -160,6 +160,7 @@ cmd_run_shell_callback(struct job *job) { struct cmd_run_shell_data *cdata = job_get_data(job); struct bufferevent *event = job_get_event(job); + struct cmdq_item *item = cdata->item; char *cmd = cdata->cmd, *msg = NULL, *line; size_t size; int retcode, status; @@ -189,13 +190,17 @@ cmd_run_shell_callback(struct job *job) } else if (WIFSIGNALED(status)) { retcode = WTERMSIG(status); xasprintf(&msg, "'%s' terminated by signal %d", cmd, retcode); + retcode += 128; } if (msg != NULL) cmd_run_shell_print(job, msg); free(msg); - if (cdata->item != NULL) - cmdq_continue(cdata->item); + if (item != NULL) { + if (item->client != NULL && item->client->session == NULL) + item->client->retval = retcode; + cmdq_continue(item); + } } static void |