diff options
author | Nicholas Marriott <nicm@cvs.openbsd.org> | 2017-01-24 20:24:55 +0000 |
---|---|---|
committer | Nicholas Marriott <nicm@cvs.openbsd.org> | 2017-01-24 20:24:55 +0000 |
commit | 2c56b13a10dace390443dfba298b2d9df40a2770 (patch) | |
tree | bd4a7928364d59d65a15364bb9c3297744dabb2b /usr.bin/tmux/cmd-set-option.c | |
parent | 6feccbfb8530026d713a2a90c60108635fb3abeb (diff) |
Fix set -u on array options.
Diffstat (limited to 'usr.bin/tmux/cmd-set-option.c')
-rw-r--r-- | usr.bin/tmux/cmd-set-option.c | 32 |
1 files changed, 16 insertions, 16 deletions
diff --git a/usr.bin/tmux/cmd-set-option.c b/usr.bin/tmux/cmd-set-option.c index 7b9d511b2fc..54422692a1f 100644 --- a/usr.bin/tmux/cmd-set-option.c +++ b/usr.bin/tmux/cmd-set-option.c @@ -1,4 +1,4 @@ -/* $OpenBSD: cmd-set-option.c,v 1.108 2017/01/24 19:11:46 nicm Exp $ */ +/* $OpenBSD: cmd-set-option.c,v 1.109 2017/01/24 20:24:54 nicm Exp $ */ /* * Copyright (c) 2007 Nicholas Marriott <nicholas.marriott@gmail.com> @@ -68,6 +68,7 @@ static enum cmd_retval cmd_set_option_exec(struct cmd *self, struct cmdq_item *item) { struct args *args = self->args; + int append = args_has(args, 'a'); struct cmd_find_state *fs = &item->state.tflag; struct session *s = fs->s; struct winlink *wl = fs->wl; @@ -160,17 +161,6 @@ cmd_set_option_exec(struct cmd *self, struct cmdq_item *item) cmdq_error(item, "not an array: %s", args->argv[0]); return (CMD_RETURN_ERROR); } - } else if (*name != '@' && options_array_size(parent, NULL) != -1) { - if (value == NULL) { - cmdq_error(item, "empty value"); - return (-1); - } - if (o == NULL) - o = options_empty(oo, options_table_entry(parent)); - if (!args_has(args, 'a')) - options_array_clear(o); - options_array_assign(o, value); - return (CMD_RETURN_NORMAL); } /* With -o, check this option is not already set. */ @@ -204,16 +194,26 @@ cmd_set_option_exec(struct cmd *self, struct cmdq_item *item) options_remove(o); } else options_array_set(o, idx, NULL, 0); - } else if (*name == '@') - options_set_string(oo, name, args_has(args, 'a'), "%s", value); - else if (idx == -1) { + } else if (*name == '@') { + if (value == NULL) { + cmdq_error(item, "empty value"); + return (CMD_RETURN_ERROR); + } + options_set_string(oo, name, append, "%s", value); + } else if (idx == -1 && options_array_size(parent, NULL) == -1) { error = cmd_set_option_set(self, item, oo, parent, value); if (error != 0) return (CMD_RETURN_ERROR); } else { + if (value == NULL) { + cmdq_error(item, "empty value"); + return (CMD_RETURN_ERROR); + } if (o == NULL) o = options_empty(oo, options_table_entry(parent)); - if (options_array_set(o, idx, value, 1) != 0) { + if (idx == -1) + options_array_assign(o, value); + else if (options_array_set(o, idx, value, append) != 0) { cmdq_error(item, "invalid index: %s", args->argv[0]); return (CMD_RETURN_ERROR); } |