aboutsummaryrefslogtreecommitdiff
path: root/mode-tree.c
diff options
context:
space:
mode:
authorThomas Adam <thomas@xteddy.org>2020-04-13 22:01:30 +0100
committerThomas Adam <thomas@xteddy.org>2020-04-13 22:01:30 +0100
commit2159ff3256df4b823dfaed24e64047249cf079c2 (patch)
tree5652805f202533dd5367bac6659bcf1d558a9348 /mode-tree.c
parentacc00cd13a767067f85ed27d52ad543c9a58869c (diff)
parent187277eaadc4a675659bf7ede88f50bfe6cc7be9 (diff)
downloadrtmux-2159ff3256df4b823dfaed24e64047249cf079c2.tar.gz
rtmux-2159ff3256df4b823dfaed24e64047249cf079c2.tar.bz2
rtmux-2159ff3256df4b823dfaed24e64047249cf079c2.zip
Merge branch 'obsd-master'
Diffstat (limited to 'mode-tree.c')
-rw-r--r--mode-tree.c40
1 files changed, 13 insertions, 27 deletions
diff --git a/mode-tree.c b/mode-tree.c
index d9af2ee3..0177d618 100644
--- a/mode-tree.c
+++ b/mode-tree.c
@@ -1063,36 +1063,22 @@ void
mode_tree_run_command(struct client *c, struct cmd_find_state *fs,
const char *template, const char *name)
{
- struct cmdq_item *new_item;
- struct cmdq_state *new_state;
- char *command;
- struct cmd_parse_result *pr;
+ struct cmdq_state *state;
+ char *command, *error;
+ enum cmd_parse_status status;
command = cmd_template_replace(template, name, 1);
- if (command == NULL || *command == '\0') {
- free(command);
- return;
- }
-
- pr = cmd_parse_from_string(command, NULL);
- switch (pr->status) {
- case CMD_PARSE_EMPTY:
- break;
- case CMD_PARSE_ERROR:
- if (c != NULL) {
- *pr->error = toupper((u_char)*pr->error);
- status_message_set(c, "%s", pr->error);
+ if (command != NULL && *command != '\0') {
+ state = cmdq_new_state(fs, NULL, 0);
+ status = cmd_parse_and_append(command, NULL, c, state, &error);
+ if (status == CMD_PARSE_ERROR) {
+ if (c != NULL) {
+ *error = toupper((u_char)*error);
+ status_message_set(c, "%s", error);
+ }
+ free(error);
}
- free(pr->error);
- break;
- case CMD_PARSE_SUCCESS:
- new_state = cmdq_new_state(fs, NULL, 0);
- new_item = cmdq_get_command(pr->cmdlist, new_state);
- cmdq_free_state(new_state);
- cmdq_append(c, new_item);
- cmd_list_free(pr->cmdlist);
- break;
+ cmdq_free_state(state);
}
-
free(command);
}