diff options
author | nicm <nicm> | 2020-06-16 08:18:34 +0000 |
---|---|---|
committer | nicm <nicm> | 2020-06-16 08:18:34 +0000 |
commit | 1bf9555e4f1ad19e1e6f97ede6fb19808ff1c267 (patch) | |
tree | 517c3ac9fd211c1294523af5f9e11104ae41edaa /options.c | |
parent | afe4ea4250073e482c6ec6accfc539f873df6977 (diff) | |
download | rtmux-1bf9555e4f1ad19e1e6f97ede6fb19808ff1c267.tar.gz rtmux-1bf9555e4f1ad19e1e6f97ede6fb19808ff1c267.tar.bz2 rtmux-1bf9555e4f1ad19e1e6f97ede6fb19808ff1c267.zip |
d and D keys to reset to default in customize mode.
Diffstat (limited to 'options.c')
-rw-r--r-- | options.c | 21 |
1 files changed, 20 insertions, 1 deletions
@@ -66,6 +66,7 @@ struct options { }; static struct options_entry *options_add(struct options *, const char *); +static void options_remove(struct options_entry *); #define OPTIONS_IS_STRING(o) \ ((o)->tableentry == NULL || \ @@ -315,7 +316,7 @@ options_add(struct options *oo, const char *name) return (o); } -void +static void options_remove(struct options_entry *o) { struct options *oo = o->owner; @@ -1106,3 +1107,21 @@ options_push_changes(const char *name) server_redraw_client(loop); } } + +int +options_remove_or_default(struct options_entry *o, int idx, char **cause) +{ + struct options *oo = o->owner; + + if (idx == -1) { + if (o->tableentry != NULL && + (oo == global_options || + oo == global_s_options || + oo == global_w_options)) + options_default(oo, o->tableentry); + else + options_remove(o); + } else if (options_array_set(o, idx, NULL, 0, cause) != 0) + return (-1); + return (0); +} |