summaryrefslogtreecommitdiffstats
path: root/cmd-show-options.c
diff options
context:
space:
mode:
authornicm <nicm>2017-05-10 13:05:41 +0000
committernicm <nicm>2017-05-10 13:05:41 +0000
commitb519551153f5451615a9d64966350400e141e540 (patch)
tree1f9c618e1107bed04b6f87f2825bc39995bd1bc4 /cmd-show-options.c
parent0e3c5ebe1a229fbb8d829c9413ae013fb2eeb1ed (diff)
Expand formats in option names and add -F flag to do so in option values as well.
Diffstat (limited to 'cmd-show-options.c')
-rw-r--r--cmd-show-options.c17
1 files changed, 14 insertions, 3 deletions
diff --git a/cmd-show-options.c b/cmd-show-options.c
index a0889c3a..f043beca 100644
--- a/cmd-show-options.c
+++ b/cmd-show-options.c
@@ -128,25 +128,36 @@ cmd_show_options_one(struct cmd *self, struct cmdq_item *item,
struct options *oo)
{
struct args *args = self->args;
+ struct client *c = cmd_find_client(item, NULL, 1);
+ struct session *s = item->target.s;
+ struct winlink *wl = item->target.wl;
struct options_entry *o;
int idx, ambiguous;
- const char *name = args->argv[0];
+ char *name;
+ name = format_single(item, args->argv[0], c, s, wl, NULL);
o = options_match_get(oo, name, &idx, 1, &ambiguous);
if (o == NULL) {
- if (args_has(args, 'q'))
+ if (args_has(args, 'q')) {
+ free(name);
return (CMD_RETURN_NORMAL);
+ }
if (ambiguous) {
cmdq_error(item, "ambiguous option: %s", name);
+ free(name);
return (CMD_RETURN_ERROR);
}
if (*name != '@' &&
- options_match_get(oo, name, &idx, 0, &ambiguous) != NULL)
+ options_match_get(oo, name, &idx, 0, &ambiguous) != NULL) {
+ free(name);
return (CMD_RETURN_NORMAL);
+ }
cmdq_error(item, "unknown option: %s", name);
+ free(name);
return (CMD_RETURN_ERROR);
}
cmd_show_options_print(self, item, o, idx);
+ free(name);
return (CMD_RETURN_NORMAL);
}