summaryrefslogtreecommitdiffstats
path: root/cmd-confirm-before.c
diff options
context:
space:
mode:
authornicm <nicm>2020-04-13 18:59:41 +0000
committernicm <nicm>2020-04-13 18:59:41 +0000
commit187277eaadc4a675659bf7ede88f50bfe6cc7be9 (patch)
treec8bc4105ea95d9cc1111e60ec84172f5e25dfa3a /cmd-confirm-before.c
parent34804f2709a16dca45dc072fb53d03f79db61e51 (diff)
Add helpers for the simple case of parse string and add to command queue.
Diffstat (limited to 'cmd-confirm-before.c')
-rw-r--r--cmd-confirm-before.c23
1 files changed, 6 insertions, 17 deletions
diff --git a/cmd-confirm-before.c b/cmd-confirm-before.c
index 7850706e..026d0e11 100644
--- a/cmd-confirm-before.c
+++ b/cmd-confirm-before.c
@@ -87,8 +87,8 @@ cmd_confirm_before_callback(struct client *c, void *data, const char *s,
__unused int done)
{
struct cmd_confirm_before_data *cdata = data;
- struct cmdq_item *new_item;
- struct cmd_parse_result *pr;
+ char *error;
+ enum cmd_parse_status status;
if (c->flags & CLIENT_DEAD)
return (0);
@@ -98,21 +98,10 @@ cmd_confirm_before_callback(struct client *c, void *data, const char *s,
if (tolower((u_char)s[0]) != 'y' || s[1] != '\0')
return (0);
- pr = cmd_parse_from_string(cdata->cmd, NULL);
- switch (pr->status) {
- case CMD_PARSE_EMPTY:
- new_item = NULL;
- break;
- case CMD_PARSE_ERROR:
- new_item = cmdq_get_error(pr->error);
- free(pr->error);
- cmdq_append(c, new_item);
- break;
- case CMD_PARSE_SUCCESS:
- new_item = cmdq_get_command(pr->cmdlist, NULL);
- cmd_list_free(pr->cmdlist);
- cmdq_append(c, new_item);
- break;
+ status = cmd_parse_and_append(cdata->cmd, NULL, c, NULL, &error);
+ if (status == CMD_PARSE_ERROR) {
+ cmdq_append(c, cmdq_get_error(error));
+ free(error);
}
return (0);