diff options
author | nicm <nicm> | 2021-08-20 17:53:54 +0000 |
---|---|---|
committer | nicm <nicm> | 2021-08-20 17:53:54 +0000 |
commit | 6cbc83c6a64f272575aac1ee32cc0a0b1cb75c7b (patch) | |
tree | e9fbbcc2c2c0ee34e2926aa569528b556b025484 | |
parent | e463e8622dff28394145868a124b10101afc2269 (diff) | |
download | rtmux-6cbc83c6a64f272575aac1ee32cc0a0b1cb75c7b.tar.gz rtmux-6cbc83c6a64f272575aac1ee32cc0a0b1cb75c7b.tar.bz2 rtmux-6cbc83c6a64f272575aac1ee32cc0a0b1cb75c7b.zip |
Add a way to create an empty arguments set.
-rw-r--r-- | arguments.c | 14 | ||||
-rw-r--r-- | cmd-find-window.c | 4 | ||||
-rw-r--r-- | tmux.h | 1 |
3 files changed, 15 insertions, 4 deletions
diff --git a/arguments.c b/arguments.c index dd92a952..91141b99 100644 --- a/arguments.c +++ b/arguments.c @@ -64,6 +64,17 @@ args_find(struct args *args, u_char flag) return (RB_FIND(args_tree, &args->tree, &entry)); } +/* Create an empty arguments set. */ +struct args * +args_create(void) +{ + struct args *args; + + args = xcalloc(1, sizeof *args); + RB_INIT(&args->tree); + return (args); +} + /* Parse an argv and argc into a new argument set. */ struct args * args_parse(const char *template, int argc, char **argv) @@ -71,12 +82,11 @@ args_parse(const char *template, int argc, char **argv) struct args *args; int opt; - args = xcalloc(1, sizeof *args); - optreset = 1; optind = 1; optarg = NULL; + args = args_create(); while ((opt = getopt(argc, argv, template)) != -1) { if (opt < 0) continue; diff --git a/cmd-find-window.c b/cmd-find-window.c index 4cd155e4..43f5f9be 100644 --- a/cmd-find-window.c +++ b/cmd-find-window.c @@ -48,7 +48,7 @@ cmd_find_window_exec(struct cmd *self, struct cmdq_item *item) struct cmd_find_state *target = cmdq_get_target(item); struct window_pane *wp = target->wp; const char *s = args->argv[0], *suffix = ""; - char *filter, *argv = { NULL }; + char *filter; int C, N, T; C = args_has(args, 'C'); @@ -91,7 +91,7 @@ cmd_find_window_exec(struct cmd *self, struct cmdq_item *item) else xasprintf(&filter, "#{m%s:*%s*,#{pane_title}}", suffix, s); - new_args = args_parse("", 1, &argv); + new_args = args_create(); if (args_has(args, 'Z')) args_set(new_args, 'Z', NULL); args_set(new_args, 'f', filter); @@ -2182,6 +2182,7 @@ int tty_keys_next(struct tty *); /* arguments.c */ void args_set(struct args *, u_char, const char *); +struct args *args_create(void); struct args *args_parse(const char *, int, char **); void args_free(struct args *); char *args_print(struct args *); |