summaryrefslogtreecommitdiff
path: root/usr.bin/tmux/cmd-set-option.c
diff options
context:
space:
mode:
authorNicholas Marriott <nicm@cvs.openbsd.org>2017-01-24 20:24:55 +0000
committerNicholas Marriott <nicm@cvs.openbsd.org>2017-01-24 20:24:55 +0000
commit2c56b13a10dace390443dfba298b2d9df40a2770 (patch)
treebd4a7928364d59d65a15364bb9c3297744dabb2b /usr.bin/tmux/cmd-set-option.c
parent6feccbfb8530026d713a2a90c60108635fb3abeb (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.c32
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);
}