summaryrefslogtreecommitdiffstats
path: root/cmd-show-options.c
diff options
context:
space:
mode:
authorTiago Cunha <tcunha@gmx.com>2009-12-04 22:11:23 +0000
committerTiago Cunha <tcunha@gmx.com>2009-12-04 22:11:23 +0000
commit1caa73afb4da381425160cbff68284a4dab1470b (patch)
treea5fa780cb150af303f72d4ec736fba9316d293a1 /cmd-show-options.c
parentddb5bb80fa9b24f47a1e5af9d808427d316bcf4a (diff)
Sync OpenBSD patchset 580:
Eliminate duplicate code and ease the passage for server-wide options by adding a -w flag to set-option and show-options and making setw and showw aliases to set -w and show -w. Note: setw and showw are still there, but now aliases for set -w and show -w.
Diffstat (limited to 'cmd-show-options.c')
-rw-r--r--cmd-show-options.c40
1 files changed, 28 insertions, 12 deletions
diff --git a/cmd-show-options.c b/cmd-show-options.c
index 860fc45a..94095676 100644
--- a/cmd-show-options.c
+++ b/cmd-show-options.c
@@ -1,4 +1,4 @@
-/* $Id: cmd-show-options.c,v 1.18 2009-11-14 17:56:39 tcunha Exp $ */
+/* $Id: cmd-show-options.c,v 1.19 2009-12-04 22:11:23 tcunha Exp $ */
/*
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
@@ -31,8 +31,8 @@ int cmd_show_options_exec(struct cmd *, struct cmd_ctx *);
const struct cmd_entry cmd_show_options_entry = {
"show-options", "show",
- "[-g] " CMD_TARGET_SESSION_USAGE,
- 0, "g",
+ "[-gw] [-t target-session|target-window]",
+ 0, "gw",
cmd_target_init,
cmd_target_parse,
cmd_show_options_exec,
@@ -43,25 +43,41 @@ const struct cmd_entry cmd_show_options_entry = {
int
cmd_show_options_exec(struct cmd *self, struct cmd_ctx *ctx)
{
- struct cmd_target_data *data = self->data;
+ struct cmd_target_data *data = self->data;
+ const struct set_option_entry *table;
struct session *s;
+ struct winlink *wl;
struct options *oo;
struct options_entry *o;
const struct set_option_entry *entry;
const char *optval;
- if (cmd_check_flag(data->chflags, 'g'))
- oo = &global_s_options;
- else {
- if ((s = cmd_find_session(ctx, data->target)) == NULL)
- return (-1);
- oo = &s->options;
+ if (cmd_check_flag(data->chflags, 'w')) {
+ table = set_window_option_table;
+ if (cmd_check_flag(data->chflags, 'g'))
+ oo = &global_w_options;
+ else {
+ wl = cmd_find_window(ctx, data->target, NULL);
+ if (wl == NULL)
+ return (-1);
+ oo = &wl->window->options;
+ }
+ } else {
+ table = set_session_option_table;
+ if (cmd_check_flag(data->chflags, 'g'))
+ oo = &global_s_options;
+ else {
+ s = cmd_find_session(ctx, data->target);
+ if (s == NULL)
+ return (-1);
+ oo = &s->options;
+ }
}
- for (entry = set_option_table; entry->name != NULL; entry++) {
+ for (entry = table; entry->name != NULL; entry++) {
if ((o = options_find1(oo, entry->name)) == NULL)
continue;
- optval = set_option_print(entry, o);
+ optval = cmd_set_option_print(entry, o);
ctx->print(ctx, "%s %s", entry->name, optval);
}