1041394f3SDevin Teske /*-
2*9d9cc246SDevin Teske * Copyright (c) 2013-2015 Devin Teske <dteske@FreeBSD.org>
3041394f3SDevin Teske * All rights reserved.
4041394f3SDevin Teske *
5041394f3SDevin Teske * Redistribution and use in source and binary forms, with or without
6041394f3SDevin Teske * modification, are permitted provided that the following conditions
7041394f3SDevin Teske * are met:
8041394f3SDevin Teske * 1. Redistributions of source code must retain the above copyright
9041394f3SDevin Teske * notice, this list of conditions and the following disclaimer.
10041394f3SDevin Teske * 2. Redistributions in binary form must reproduce the above copyright
11041394f3SDevin Teske * notice, this list of conditions and the following disclaimer in the
12041394f3SDevin Teske * documentation and/or other materials provided with the distribution.
13041394f3SDevin Teske *
14041394f3SDevin Teske * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
15041394f3SDevin Teske * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
16041394f3SDevin Teske * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
17041394f3SDevin Teske * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
18041394f3SDevin Teske * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
19041394f3SDevin Teske * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
20041394f3SDevin Teske * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
21041394f3SDevin Teske * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
22041394f3SDevin Teske * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
23041394f3SDevin Teske * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
24041394f3SDevin Teske * SUCH DAMAGE.
25041394f3SDevin Teske */
26041394f3SDevin Teske
27041394f3SDevin Teske #include <sys/types.h>
28041394f3SDevin Teske
29041394f3SDevin Teske #include <err.h>
30041394f3SDevin Teske #include <errno.h>
31041394f3SDevin Teske #include <figpar.h>
32041394f3SDevin Teske #include <limits.h>
33041394f3SDevin Teske #include <stdio.h>
34041394f3SDevin Teske #include <stdlib.h>
35041394f3SDevin Teske #include <string.h>
36041394f3SDevin Teske #include <string_m.h>
37041394f3SDevin Teske
38041394f3SDevin Teske #include "dialogrc.h"
39041394f3SDevin Teske
40041394f3SDevin Teske #define STR_BUFSIZE 255
41041394f3SDevin Teske
42041394f3SDevin Teske /* dialog(1) `.dialogrc' characteristics */
43041394f3SDevin Teske uint8_t use_colors = 1;
44041394f3SDevin Teske uint8_t use_shadow = 1;
45041394f3SDevin Teske char gauge_color[STR_BUFSIZE] = "47b"; /* (BLUE,WHITE,ON) */
46041394f3SDevin Teske char separator[STR_BUFSIZE] = "";
47041394f3SDevin Teske
48041394f3SDevin Teske /* Function prototypes */
49*9d9cc246SDevin Teske static int setattr(struct figpar_config *, uint32_t, char *, char *);
50*9d9cc246SDevin Teske static int setbool(struct figpar_config *, uint32_t, char *, char *);
51*9d9cc246SDevin Teske static int setnum(struct figpar_config *, uint32_t, char *, char *);
52*9d9cc246SDevin Teske static int setstr(struct figpar_config *, uint32_t, char *, char *);
53041394f3SDevin Teske
54041394f3SDevin Teske /*
55041394f3SDevin Teske * Anatomy of DIALOGRC (~/.dialogrc by default)
56041394f3SDevin Teske * NOTE: Must appear after private function prototypes (above)
57041394f3SDevin Teske * NB: Brace-initialization of union requires cast to *first* member of union
58041394f3SDevin Teske */
59*9d9cc246SDevin Teske static struct figpar_config dialogrc_config[] = {
60*9d9cc246SDevin Teske /* TYPE DIRECTIVE DEFAULT HANDLER */
61*9d9cc246SDevin Teske {FIGPAR_TYPE_INT, "aspect", {(void *)0}, &setnum},
62*9d9cc246SDevin Teske {FIGPAR_TYPE_STR, "separate_widget", {separator}, &setstr},
63*9d9cc246SDevin Teske {FIGPAR_TYPE_INT, "tab_len", {(void *)0}, &setnum},
64*9d9cc246SDevin Teske {FIGPAR_TYPE_BOOL, "visit_items", {(void *)0}, &setbool},
65*9d9cc246SDevin Teske {FIGPAR_TYPE_BOOL, "use_shadow", {(void *)1}, &setbool},
66*9d9cc246SDevin Teske {FIGPAR_TYPE_BOOL, "use_colors", {(void *)1}, &setbool},
67*9d9cc246SDevin Teske {FIGPAR_TYPE_STR, "screen_color", {NULL}, &setattr},
68*9d9cc246SDevin Teske {FIGPAR_TYPE_STR, "shadow_color", {NULL}, &setattr},
69*9d9cc246SDevin Teske {FIGPAR_TYPE_STR, "dialog_color", {NULL}, &setattr},
70*9d9cc246SDevin Teske {FIGPAR_TYPE_STR, "title_color", {NULL}, &setattr},
71*9d9cc246SDevin Teske {FIGPAR_TYPE_STR, "border_color", {NULL}, &setattr},
72*9d9cc246SDevin Teske {FIGPAR_TYPE_STR, "button_active_color", {NULL}, &setattr},
73*9d9cc246SDevin Teske {FIGPAR_TYPE_STR, "button_inactive_color", {NULL}, &setattr},
74*9d9cc246SDevin Teske {FIGPAR_TYPE_STR, "button_key_active_color", {NULL}, &setattr},
75*9d9cc246SDevin Teske {FIGPAR_TYPE_STR, "button_key_inactive_color", {NULL}, &setattr},
76*9d9cc246SDevin Teske {FIGPAR_TYPE_STR, "button_label_active_color", {NULL}, &setattr},
77*9d9cc246SDevin Teske {FIGPAR_TYPE_STR, "button_label_inactive_color", {NULL}, &setattr},
78*9d9cc246SDevin Teske {FIGPAR_TYPE_STR, "inputbox_color", {NULL}, &setattr},
79*9d9cc246SDevin Teske {FIGPAR_TYPE_STR, "inputbox_border_color", {NULL}, &setattr},
80*9d9cc246SDevin Teske {FIGPAR_TYPE_STR, "searchbox_color", {NULL}, &setattr},
81*9d9cc246SDevin Teske {FIGPAR_TYPE_STR, "searchbox_title_color", {NULL}, &setattr},
82*9d9cc246SDevin Teske {FIGPAR_TYPE_STR, "searchbox_border_color", {NULL}, &setattr},
83*9d9cc246SDevin Teske {FIGPAR_TYPE_STR, "position_indicator_color", {NULL}, &setattr},
84*9d9cc246SDevin Teske {FIGPAR_TYPE_STR, "menubox_color", {NULL}, &setattr},
85*9d9cc246SDevin Teske {FIGPAR_TYPE_STR, "menubox_border_color", {NULL}, &setattr},
86*9d9cc246SDevin Teske {FIGPAR_TYPE_STR, "item_color", {NULL}, &setattr},
87*9d9cc246SDevin Teske {FIGPAR_TYPE_STR, "item_selected_color", {NULL}, &setattr},
88*9d9cc246SDevin Teske {FIGPAR_TYPE_STR, "tag_color", {NULL}, &setattr},
89*9d9cc246SDevin Teske {FIGPAR_TYPE_STR, "tag_selected_color", {NULL}, &setattr},
90*9d9cc246SDevin Teske {FIGPAR_TYPE_STR, "tag_key_color", {NULL}, &setattr},
91*9d9cc246SDevin Teske {FIGPAR_TYPE_STR, "tag_key_selected_color", {NULL}, &setattr},
92*9d9cc246SDevin Teske {FIGPAR_TYPE_STR, "check_color", {NULL}, &setattr},
93*9d9cc246SDevin Teske {FIGPAR_TYPE_STR, "check_selected_color", {NULL}, &setattr},
94*9d9cc246SDevin Teske {FIGPAR_TYPE_STR, "uarrow_color", {NULL}, &setattr},
95*9d9cc246SDevin Teske {FIGPAR_TYPE_STR, "darrow_color", {NULL}, &setattr},
96*9d9cc246SDevin Teske {FIGPAR_TYPE_STR, "itemhelp_color", {NULL}, &setattr},
97*9d9cc246SDevin Teske {FIGPAR_TYPE_STR, "form_active_text_color", {NULL}, &setattr},
98*9d9cc246SDevin Teske {FIGPAR_TYPE_STR, "form_text_color", {NULL}, &setattr},
99*9d9cc246SDevin Teske {FIGPAR_TYPE_STR, "form_item_readonly_color", {NULL}, &setattr},
100*9d9cc246SDevin Teske {FIGPAR_TYPE_STR, "gauge_color", {gauge_color}, &setattr},
101041394f3SDevin Teske {0, NULL, {0}, NULL}
102041394f3SDevin Teske };
103041394f3SDevin Teske
104041394f3SDevin Teske /*
105041394f3SDevin Teske * figpar call-back for interpreting value as .dialogrc `Attribute'
106041394f3SDevin Teske */
107041394f3SDevin Teske static int
setattr(struct figpar_config * option,uint32_t line __unused,char * directive __unused,char * value)108*9d9cc246SDevin Teske setattr(struct figpar_config *option, uint32_t line __unused,
109041394f3SDevin Teske char *directive __unused, char *value)
110041394f3SDevin Teske {
111041394f3SDevin Teske char *cp = value;
112041394f3SDevin Teske char *val;
113041394f3SDevin Teske size_t len;
114041394f3SDevin Teske char attrbuf[4];
115041394f3SDevin Teske
116041394f3SDevin Teske if (option == NULL) {
117041394f3SDevin Teske warnx("%s:%d:%s: Missing callback parameter", __FILE__,
118041394f3SDevin Teske __LINE__, __func__);
119041394f3SDevin Teske return (-1); /* Abort processing */
120041394f3SDevin Teske }
121041394f3SDevin Teske
122041394f3SDevin Teske /* Allocate memory for the data if not already done */
123041394f3SDevin Teske if (option->value.str == NULL) {
124041394f3SDevin Teske if ((option->value.str = malloc(STR_BUFSIZE)) == NULL)
125041394f3SDevin Teske return (-1);
126041394f3SDevin Teske }
127041394f3SDevin Teske
128041394f3SDevin Teske /*
129041394f3SDevin Teske * If the first character is left-parenthesis, the format is
130041394f3SDevin Teske * `(background,foreground,highlight)' otherwise, we should take it
131041394f3SDevin Teske * as a reference to another color.
132041394f3SDevin Teske */
133041394f3SDevin Teske if (*cp != '(') {
134041394f3SDevin Teske /* Copy the [current] value from the referenced color */
135041394f3SDevin Teske val = dialogrc_config_option(cp)->value.str;
136041394f3SDevin Teske if (val != NULL)
137041394f3SDevin Teske snprintf(option->value.str, STR_BUFSIZE, "%s", val);
138041394f3SDevin Teske
139041394f3SDevin Teske return (0);
140041394f3SDevin Teske } else
141041394f3SDevin Teske cp++;
142041394f3SDevin Teske
143041394f3SDevin Teske strtolower(cp);
144041394f3SDevin Teske
145041394f3SDevin Teske /* Initialize the attrbuf (fg,bg,hi,NUL) */
146041394f3SDevin Teske attrbuf[0] = '0';
147041394f3SDevin Teske attrbuf[1] = '0';
148041394f3SDevin Teske attrbuf[2] = 'B'; /* \ZB = disable; \Zb = enable (see dialog(1)) */
149041394f3SDevin Teske attrbuf[3] = '\0';
150041394f3SDevin Teske
151041394f3SDevin Teske /* Interpret the foreground color */
152041394f3SDevin Teske if (strncmp(cp, "red,", 4) == 0) attrbuf[0] = '1';
153041394f3SDevin Teske else if (strncmp(cp, "green,", 6) == 0) attrbuf[0] = '2';
154041394f3SDevin Teske else if (strncmp(cp, "yellow,", 7) == 0) attrbuf[0] = '3';
155041394f3SDevin Teske else if (strncmp(cp, "blue,", 5) == 0) attrbuf[0] = '4';
156041394f3SDevin Teske else if (strncmp(cp, "magenta,", 8) == 0) attrbuf[0] = '5';
157041394f3SDevin Teske else if (strncmp(cp, "cyan,", 5) == 0) attrbuf[0] = '6';
158041394f3SDevin Teske else if (strncmp(cp, "white,", 6) == 0) attrbuf[0] = '7';
159041394f3SDevin Teske else if (strncmp(cp, "black,", 6) == 0) attrbuf[0] = '8';
160041394f3SDevin Teske
161041394f3SDevin Teske /* Advance to the background color */
162041394f3SDevin Teske cp = strchr(cp, ',');
163041394f3SDevin Teske if (cp == NULL)
164041394f3SDevin Teske goto write_attrbuf;
165041394f3SDevin Teske else
166041394f3SDevin Teske cp++;
167041394f3SDevin Teske
168041394f3SDevin Teske /* Interpret the background color */
169041394f3SDevin Teske if (strncmp(cp, "red,", 4) == 0) attrbuf[1] = '1';
170041394f3SDevin Teske else if (strncmp(cp, "green,", 6) == 0) attrbuf[1] = '2';
171041394f3SDevin Teske else if (strncmp(cp, "yellow,", 7) == 0) attrbuf[1] = '3';
172041394f3SDevin Teske else if (strncmp(cp, "blue,", 5) == 0) attrbuf[1] = '4';
173041394f3SDevin Teske else if (strncmp(cp, "magenta,", 8) == 0) attrbuf[1] = '5';
174041394f3SDevin Teske else if (strncmp(cp, "cyan,", 5) == 0) attrbuf[1] = '6';
175041394f3SDevin Teske else if (strncmp(cp, "white,", 6) == 0) attrbuf[1] = '7';
176041394f3SDevin Teske else if (strncmp(cp, "black,", 6) == 0) attrbuf[1] = '8';
177041394f3SDevin Teske
178041394f3SDevin Teske /* Advance to the highlight */
179041394f3SDevin Teske cp = strchr(cp, ',');
180041394f3SDevin Teske if (cp == NULL)
181041394f3SDevin Teske goto write_attrbuf;
182041394f3SDevin Teske else
183041394f3SDevin Teske cp++;
184041394f3SDevin Teske
185041394f3SDevin Teske /* Trim trailing parenthesis */
186041394f3SDevin Teske len = strlen(cp);
187041394f3SDevin Teske if (cp[len - 1] == ')')
188041394f3SDevin Teske cp[len - 1] = '\0';
189041394f3SDevin Teske
190041394f3SDevin Teske /* Interpret the highlight (initialized to off above) */
191041394f3SDevin Teske if (strcmp(cp, "on") == 0 || strncmp(cp, "on,", 3) == 0)
192041394f3SDevin Teske attrbuf[2] = 'b'; /* \Zb = enable bold (see dialog(1)) */
193041394f3SDevin Teske
194041394f3SDevin Teske write_attrbuf:
195041394f3SDevin Teske sprintf(option->value.str, "%s", attrbuf);
196041394f3SDevin Teske
197041394f3SDevin Teske return (0);
198041394f3SDevin Teske }
199041394f3SDevin Teske
200041394f3SDevin Teske /*
201041394f3SDevin Teske * figpar call-back for interpreting value as .dialogrc `Boolean'
202041394f3SDevin Teske */
203041394f3SDevin Teske static int
setbool(struct figpar_config * option,uint32_t line __unused,char * directive __unused,char * value)204*9d9cc246SDevin Teske setbool(struct figpar_config *option, uint32_t line __unused,
205041394f3SDevin Teske char *directive __unused, char *value)
206041394f3SDevin Teske {
207041394f3SDevin Teske
208041394f3SDevin Teske if (option == NULL) {
209041394f3SDevin Teske warnx("%s:%d:%s: Missing callback parameter", __FILE__,
210041394f3SDevin Teske __LINE__, __func__);
211041394f3SDevin Teske return (-1); /* Abort processing */
212041394f3SDevin Teske }
213041394f3SDevin Teske
214041394f3SDevin Teske /* Assume ON, check for OFF (case-insensitive) */
215041394f3SDevin Teske option->value.boolean = 1;
216041394f3SDevin Teske strtolower(value);
217041394f3SDevin Teske if (strcmp(value, "off") == 0)
218041394f3SDevin Teske option->value.boolean = 0;
219041394f3SDevin Teske
220041394f3SDevin Teske return (0);
221041394f3SDevin Teske }
222041394f3SDevin Teske
223041394f3SDevin Teske /*
224041394f3SDevin Teske * figpar call-back for interpreting value as .dialogrc `Number'
225041394f3SDevin Teske */
226041394f3SDevin Teske static int
setnum(struct figpar_config * option,uint32_t line __unused,char * directive __unused,char * value)227*9d9cc246SDevin Teske setnum(struct figpar_config *option, uint32_t line __unused,
228964b46aaSDevin Teske char *directive __unused, char *value)
229041394f3SDevin Teske {
230041394f3SDevin Teske
231041394f3SDevin Teske if (option == NULL) {
232041394f3SDevin Teske warnx("%s:%d:%s: Missing callback parameter", __FILE__,
233041394f3SDevin Teske __LINE__, __func__);
234041394f3SDevin Teske return (-1); /* Abort processing */
235041394f3SDevin Teske }
236041394f3SDevin Teske
237041394f3SDevin Teske /* Convert the string to a 32-bit signed integer */
238041394f3SDevin Teske option->value.num = (int32_t)strtol(value, (char **)NULL, 10);
239041394f3SDevin Teske
240041394f3SDevin Teske return (0);
241041394f3SDevin Teske }
242041394f3SDevin Teske
243041394f3SDevin Teske /*
244041394f3SDevin Teske * figpar call-back for interpreting value as .dialogrc `String'
245041394f3SDevin Teske */
246041394f3SDevin Teske static int
setstr(struct figpar_config * option,uint32_t line __unused,char * directive __unused,char * value)247*9d9cc246SDevin Teske setstr(struct figpar_config *option, uint32_t line __unused,
248964b46aaSDevin Teske char *directive __unused, char *value)
249041394f3SDevin Teske {
250041394f3SDevin Teske size_t len;
251041394f3SDevin Teske
252041394f3SDevin Teske if (option == NULL) {
253041394f3SDevin Teske warnx("%s:%d:%s: Missing callback parameter", __FILE__,
254041394f3SDevin Teske __LINE__, __func__);
255041394f3SDevin Teske return (-1); /* Abort processing */
256041394f3SDevin Teske }
257041394f3SDevin Teske
258041394f3SDevin Teske /* Allocate memory for the data if not already done */
259041394f3SDevin Teske if (option->value.str == NULL) {
260041394f3SDevin Teske if ((option->value.str = malloc(STR_BUFSIZE)) == NULL)
261041394f3SDevin Teske return (-1);
262041394f3SDevin Teske }
263041394f3SDevin Teske
264041394f3SDevin Teske /* Trim leading quote */
265041394f3SDevin Teske if (*value == '"')
266041394f3SDevin Teske value++;
267041394f3SDevin Teske
268041394f3SDevin Teske /* Write the data into the buffer */
269041394f3SDevin Teske snprintf(option->value.str, STR_BUFSIZE, "%s", value);
270041394f3SDevin Teske
271041394f3SDevin Teske /* Trim trailing quote */
272041394f3SDevin Teske len = strlen(option->value.str);
273041394f3SDevin Teske if (option->value.str[len - 1] == '"')
274041394f3SDevin Teske option->value.str[len - 1] = '\0';
275041394f3SDevin Teske
276041394f3SDevin Teske return (0);
277041394f3SDevin Teske }
278041394f3SDevin Teske
279041394f3SDevin Teske /*
280041394f3SDevin Teske * Parse (in order of preference) $DIALOGRC or `$HOME/.dialogrc'. Returns zero
281041394f3SDevin Teske * on success, -1 on failure (and errno should be consulted).
282041394f3SDevin Teske */
283041394f3SDevin Teske int
parse_dialogrc(void)284041394f3SDevin Teske parse_dialogrc(void)
285041394f3SDevin Teske {
286041394f3SDevin Teske char *cp;
287041394f3SDevin Teske int res;
288041394f3SDevin Teske size_t len;
289041394f3SDevin Teske char path[PATH_MAX];
290041394f3SDevin Teske
291041394f3SDevin Teske /* Allow $DIALOGRC to override `$HOME/.dialogrc' default */
292041394f3SDevin Teske if ((cp = getenv(ENV_DIALOGRC)) != NULL && *cp != '\0')
293041394f3SDevin Teske snprintf(path, PATH_MAX, "%s", cp);
294041394f3SDevin Teske else if ((cp = getenv(ENV_HOME)) != NULL) {
295041394f3SDevin Teske /* Copy $HOME into buffer and append trailing `/' if missing */
296041394f3SDevin Teske snprintf(path, PATH_MAX, "%s", cp);
297041394f3SDevin Teske len = strlen(path);
298041394f3SDevin Teske cp = path + len;
299041394f3SDevin Teske if (len > 0 && len < (PATH_MAX - 1) && *(cp - 1) != '/') {
300041394f3SDevin Teske *cp++ = '/';
301041394f3SDevin Teske *cp = '\0';
302041394f3SDevin Teske len++;
303041394f3SDevin Teske }
304041394f3SDevin Teske
305041394f3SDevin Teske /* If we still have room, shove in the name of rc file */
306041394f3SDevin Teske if (len < (PATH_MAX - 1))
307041394f3SDevin Teske snprintf(cp, PATH_MAX - len, "%s", DIALOGRC);
308041394f3SDevin Teske } else {
309041394f3SDevin Teske /* Like dialog(1), don't process a file if $HOME is unset */
310041394f3SDevin Teske errno = ENOENT;
311041394f3SDevin Teske return (-1);
312041394f3SDevin Teske }
313041394f3SDevin Teske
314041394f3SDevin Teske /* Process file (either $DIALOGRC if set, or `$HOME/.dialogrc') */
315*9d9cc246SDevin Teske res = parse_config(dialogrc_config,
316*9d9cc246SDevin Teske path, NULL, FIGPAR_BREAK_ON_EQUALS);
317041394f3SDevin Teske
318041394f3SDevin Teske /* Set some globals based on what we parsed */
319041394f3SDevin Teske use_shadow = dialogrc_config_option("use_shadow")->value.boolean;
320041394f3SDevin Teske use_colors = dialogrc_config_option("use_colors")->value.boolean;
321041394f3SDevin Teske snprintf(gauge_color, STR_BUFSIZE, "%s",
322041394f3SDevin Teske dialogrc_config_option("gauge_color")->value.str);
323041394f3SDevin Teske
324041394f3SDevin Teske return (res);
325041394f3SDevin Teske }
326041394f3SDevin Teske
327041394f3SDevin Teske /*
328041394f3SDevin Teske * Return a pointer to the `.dialogrc' config option specific to `directive' or
329*9d9cc246SDevin Teske * static figpar_dummy_config (full of NULLs) if none found (see
330964b46aaSDevin Teske * get_config_option(3); part of figpar(3)).
331041394f3SDevin Teske */
332*9d9cc246SDevin Teske struct figpar_config *
dialogrc_config_option(const char * directive)333041394f3SDevin Teske dialogrc_config_option(const char *directive)
334041394f3SDevin Teske {
335041394f3SDevin Teske return (get_config_option(dialogrc_config, directive));
336041394f3SDevin Teske }
337041394f3SDevin Teske
338041394f3SDevin Teske /*
339041394f3SDevin Teske * Free allocated items initialized by setattr() (via parse_config() callback
340041394f3SDevin Teske * matrix [dialogrc_config] used in parse_dialogrc() above).
341041394f3SDevin Teske */
342041394f3SDevin Teske void
dialogrc_free(void)343041394f3SDevin Teske dialogrc_free(void)
344041394f3SDevin Teske {
345041394f3SDevin Teske char *value;
346041394f3SDevin Teske uint32_t n;
347041394f3SDevin Teske
348041394f3SDevin Teske for (n = 0; dialogrc_config[n].directive != NULL; n++) {
349041394f3SDevin Teske if (dialogrc_config[n].action != &setattr)
350041394f3SDevin Teske continue;
351041394f3SDevin Teske value = dialogrc_config[n].value.str;
352041394f3SDevin Teske if (value != NULL && value != gauge_color) {
353041394f3SDevin Teske free(dialogrc_config[n].value.str);
354041394f3SDevin Teske dialogrc_config[n].value.str = NULL;
355041394f3SDevin Teske }
356041394f3SDevin Teske }
357041394f3SDevin Teske }
358