aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--cmd-if-shell.c9
-rw-r--r--cmd-load-buffer.c1
-rw-r--r--cmd-run-shell.c8
-rw-r--r--format.c4
4 files changed, 17 insertions, 5 deletions
diff --git a/cmd-if-shell.c b/cmd-if-shell.c
index ffdbe788..480912df 100644
--- a/cmd-if-shell.c
+++ b/cmd-if-shell.c
@@ -120,8 +120,13 @@ cmd_if_shell_exec(struct cmd *self, struct cmdq_item *item)
cdata->item = NULL;
memcpy(&cdata->mouse, &shared->mouse, sizeof cdata->mouse);
- job_run(shellcmd, s, server_client_get_cwd(item->client, s), NULL,
- cmd_if_shell_callback, cmd_if_shell_free, cdata, 0);
+ if (job_run(shellcmd, s, server_client_get_cwd(item->client, s), NULL,
+ cmd_if_shell_callback, cmd_if_shell_free, cdata, 0) == NULL) {
+ cmdq_error(item, "failed to run command: %s", shellcmd);
+ free(shellcmd);
+ free(cdata);
+ return (CMD_RETURN_ERROR);
+ }
free(shellcmd);
if (args_has(args, 'b'))
diff --git a/cmd-load-buffer.c b/cmd-load-buffer.c
index b7c299b7..47cb0ca2 100644
--- a/cmd-load-buffer.c
+++ b/cmd-load-buffer.c
@@ -87,6 +87,7 @@ cmd_load_buffer_exec(struct cmd *self, struct cmdq_item *item)
if (error != 0) {
cmdq_error(item, "-: %s", cause);
free(cause);
+ free(cdata);
return (CMD_RETURN_ERROR);
}
return (CMD_RETURN_WAIT);
diff --git a/cmd-run-shell.c b/cmd-run-shell.c
index ff12b5cd..47fceafe 100644
--- a/cmd-run-shell.c
+++ b/cmd-run-shell.c
@@ -102,8 +102,12 @@ cmd_run_shell_exec(struct cmd *self, struct cmdq_item *item)
if (!args_has(args, 'b'))
cdata->item = item;
- job_run(cdata->cmd, s, server_client_get_cwd(item->client, s), NULL,
- cmd_run_shell_callback, cmd_run_shell_free, cdata, 0);
+ if (job_run(cdata->cmd, s, server_client_get_cwd(item->client, s), NULL,
+ cmd_run_shell_callback, cmd_run_shell_free, cdata, 0) == NULL) {
+ cmdq_error(item, "failed to run command: %s", cdata->cmd);
+ free(cdata);
+ return (CMD_RETURN_ERROR);
+ }
if (args_has(args, 'b'))
return (CMD_RETURN_NORMAL);
diff --git a/format.c b/format.c
index 54e33c7a..ec3839ef 100644
--- a/format.c
+++ b/format.c
@@ -1086,8 +1086,10 @@ format_replace(struct format_tree *ft, const char *key, size_t keylen,
found = xstrdup("");
}
}
- if (format_choose(ptr + 1, &left, &right) != 0)
+ if (format_choose(ptr + 1, &left, &right) != 0) {
+ free(found);
goto fail;
+ }
if (format_true(found))
value = format_expand(ft, left);