diff options
author | Nicholas Marriott <nicm@openbsd.org> | 2009-12-10 09:16:52 +0000 |
---|---|---|
committer | Nicholas Marriott <nicm@openbsd.org> | 2009-12-10 09:16:52 +0000 |
commit | a4c9a80dacf405623698acfc971d636bbc0e43c7 (patch) | |
tree | 059539758458dfcbcd8348ea471e843f30dc0ab0 /cmd-set-option.c | |
parent | 6311bd119ed728117fd6f0073792a76c2a6b842b (diff) | |
download | rtmux-a4c9a80dacf405623698acfc971d636bbc0e43c7.tar.gz rtmux-a4c9a80dacf405623698acfc971d636bbc0e43c7.tar.bz2 rtmux-a4c9a80dacf405623698acfc971d636bbc0e43c7.zip |
Add "server options" which are server-wide and not bound to a session or
window. Set and displayed with "set -s" and "show -s".
Currently the only option is "quiet" (like command-line -q, allowing it to be
set from .tmux.conf), but others will come along.
Diffstat (limited to 'cmd-set-option.c')
-rw-r--r-- | cmd-set-option.c | 13 |
1 files changed, 10 insertions, 3 deletions
diff --git a/cmd-set-option.c b/cmd-set-option.c index 0cd7dca6..64b78448 100644 --- a/cmd-set-option.c +++ b/cmd-set-option.c @@ -48,8 +48,8 @@ void cmd_set_option_choice(struct cmd_ctx *, const struct cmd_entry cmd_set_option_entry = { "set-option", "set", - "[-aguw] [-t target-session|target-window] option [value]", - CMD_ARG12, "aguw", + "[-agsuw] [-t target-session|target-window] option [value]", + CMD_ARG12, "agsuw", NULL, cmd_target_parse, cmd_set_option_exec, @@ -73,6 +73,10 @@ const char *set_option_bell_action_list[] = { "none", "any", "current", NULL }; +const struct set_option_entry set_option_table[] = { + { "quiet", SET_OPTION_FLAG, 0, 0, NULL }, +}; + const struct set_option_entry set_session_option_table[] = { { "base-index", SET_OPTION_NUMBER, 0, INT_MAX, NULL }, { "bell-action", SET_OPTION_CHOICE, 0, 0, set_option_bell_action_list }, @@ -172,7 +176,10 @@ cmd_set_option_exec(struct cmd *self, struct cmd_ctx *ctx) u_int i; int try_again; - if (cmd_check_flag(data->chflags, 'w')) { + if (cmd_check_flag(data->chflags, 's')) { + oo = &global_options; + table = set_option_table; + } else if (cmd_check_flag(data->chflags, 'w')) { table = set_window_option_table; if (cmd_check_flag(data->chflags, 'g')) oo = &global_w_options; |