summaryrefslogtreecommitdiffstats
path: root/cmd-confirm-before.c
diff options
context:
space:
mode:
authornicm <nicm>2021-08-11 08:40:58 +0000
committernicm <nicm>2021-08-11 08:40:58 +0000
commit338ec859a463eaa4c0502116ef2857c566c9e468 (patch)
tree2f52ba1a2bd25fe9f588ebb0e67f12b4f09c8199 /cmd-confirm-before.c
parentf6755c6f2c6fd10a90984fadad4c9ac4a8a92027 (diff)
Make confirm-before optionally block the invoking client like run-shell,
GitHub issue 2819.
Diffstat (limited to 'cmd-confirm-before.c')
-rw-r--r--cmd-confirm-before.c38
1 files changed, 31 insertions, 7 deletions
diff --git a/cmd-confirm-before.c b/cmd-confirm-before.c
index 0b490b17..83f9a0f8 100644
--- a/cmd-confirm-before.c
+++ b/cmd-confirm-before.c
@@ -39,15 +39,17 @@ const struct cmd_entry cmd_confirm_before_entry = {
.name = "confirm-before",
.alias = "confirm",
- .args = { "p:t:", 1, 1 },
- .usage = "[-p prompt] " CMD_TARGET_CLIENT_USAGE " command",
+ .args = { "bp:t:", 1, 1 },
+ .usage = "[-b] [-p prompt] " CMD_TARGET_CLIENT_USAGE " command",
.flags = CMD_CLIENT_TFLAG,
.exec = cmd_confirm_before_exec
};
struct cmd_confirm_before_data {
- char *cmd;
+ char *cmd;
+ struct cmdq_item *item;
+ struct cmd_parse_input pi;
};
static enum cmd_retval
@@ -59,6 +61,7 @@ cmd_confirm_before_exec(struct cmd *self, struct cmdq_item *item)
struct cmd_find_state *target = cmdq_get_target(item);
char *cmd, *copy, *new_prompt, *ptr;
const char *prompt;
+ int wait = !args_has(args, 'b');
if ((prompt = args_get(args, 'p')) != NULL)
xasprintf(&new_prompt, "%s ", prompt);
@@ -72,12 +75,24 @@ cmd_confirm_before_exec(struct cmd *self, struct cmdq_item *item)
cdata = xmalloc(sizeof *cdata);
cdata->cmd = xstrdup(args->argv[0]);
+ memset(&cdata->pi, 0, sizeof cdata->pi);
+ cmd_get_source(self, &cdata->pi.file, &cdata->pi.line);
+ if (wait)
+ cdata->pi.item = item;
+ cdata->pi.c = tc;
+ cmd_find_copy_state(&cdata->pi.fs, target);
+
+ if (wait)
+ cdata->item = item;
+
status_prompt_set(tc, target, new_prompt, NULL,
cmd_confirm_before_callback, cmd_confirm_before_free, cdata,
PROMPT_SINGLE, PROMPT_TYPE_COMMAND);
free(new_prompt);
- return (CMD_RETURN_NORMAL);
+ if (!wait)
+ return (CMD_RETURN_NORMAL);
+ return (CMD_RETURN_WAIT);
}
static int
@@ -85,23 +100,32 @@ cmd_confirm_before_callback(struct client *c, void *data, const char *s,
__unused int done)
{
struct cmd_confirm_before_data *cdata = data;
+ const char *cmd = cdata->cmd;
char *error;
+ struct cmdq_item *item = cdata->item;
enum cmd_parse_status status;
if (c->flags & CLIENT_DEAD)
return (0);
if (s == NULL || *s == '\0')
- return (0);
+ goto out;
if (tolower((u_char)s[0]) != 'y' || s[1] != '\0')
- return (0);
+ goto out;
- status = cmd_parse_and_append(cdata->cmd, NULL, c, NULL, &error);
+ if (item != NULL) {
+ status = cmd_parse_and_insert(cmd, &cdata->pi, item,
+ cmdq_get_state(item), &error);
+ } else
+ status = cmd_parse_and_append(cmd, &cdata->pi, c, NULL, &error);
if (status == CMD_PARSE_ERROR) {
cmdq_append(c, cmdq_get_error(error));
free(error);
}
+out:
+ if (item != NULL)
+ cmdq_continue(item);
return (0);
}