summaryrefslogtreecommitdiffstats
path: root/cmd-if-shell.c
diff options
context:
space:
mode:
authornicm <nicm>2017-04-25 11:49:35 +0000
committernicm <nicm>2017-04-25 11:49:35 +0000
commiteb6fd6ff80af989ca5a2d5161f6b8de460f4c575 (patch)
tree8897816528cbd79938ceaaf9560d0a184dab77e7 /cmd-if-shell.c
parent51720146680d8fdba021dae755fc50305c9a0206 (diff)
if-shell doesn't need to queue its error message into a callback, and in
fact it can't do so because the item it was working with will have been freed. Reported by Daniel Hahler.
Diffstat (limited to 'cmd-if-shell.c')
-rw-r--r--cmd-if-shell.c20
1 files changed, 4 insertions, 16 deletions
diff --git a/cmd-if-shell.c b/cmd-if-shell.c
index 580526f8..2400b3b4 100644
--- a/cmd-if-shell.c
+++ b/cmd-if-shell.c
@@ -31,7 +31,6 @@
static enum cmd_retval cmd_if_shell_exec(struct cmd *, struct cmdq_item *);
-static enum cmd_retval cmd_if_shell_error(struct cmdq_item *, void *);
static void cmd_if_shell_callback(struct job *);
static void cmd_if_shell_free(void *);
@@ -138,17 +137,6 @@ cmd_if_shell_exec(struct cmd *self, struct cmdq_item *item)
return (CMD_RETURN_WAIT);
}
-static enum cmd_retval
-cmd_if_shell_error(struct cmdq_item *item, void *data)
-{
- char *error = data;
-
- cmdq_error(item, "%s", error);
- free(error);
-
- return (CMD_RETURN_NORMAL);
-}
-
static void
cmd_if_shell_callback(struct job *job)
{
@@ -168,10 +156,10 @@ cmd_if_shell_callback(struct job *job)
cmdlist = cmd_string_parse(cmd, file, line, &cause);
if (cmdlist == NULL) {
- if (cause != NULL)
- new_item = cmdq_get_callback(cmd_if_shell_error, cause);
- else
- new_item = NULL;
+ if (cause != NULL && cdata->item != NULL)
+ cmdq_error(cdata->item, "%s", cause);
+ free(cause);
+ new_item = NULL;
} else {
new_item = cmdq_get_command(cmdlist, NULL, &cdata->mouse, 0);
cmd_list_free(cmdlist);