mirror of
https://github.com/davatorium/rofi.git
synced 2024-11-25 13:55:34 -05:00
[Config] on -dump-config do not include -theme option.
But print the right line at the bottom. fixes: #1534
This commit is contained in:
parent
b03c072aaa
commit
f72d6135bd
2 changed files with 48 additions and 34 deletions
|
@ -1,3 +1,7 @@
|
||||||
|
v1.7.2:
|
||||||
|
- Fix building without window mode enabled.
|
||||||
|
- Do not print out the 'theme' field in confgiration on dump.
|
||||||
|
|
||||||
v1.7.1: Turtley amazing!
|
v1.7.1: Turtley amazing!
|
||||||
- [Theme] Fix highlight with only theme.
|
- [Theme] Fix highlight with only theme.
|
||||||
- Updated documentation and landing page (Thanks to RaZ0rr-Two)
|
- Updated documentation and landing page (Thanks to RaZ0rr-Two)
|
||||||
|
|
|
@ -46,18 +46,15 @@
|
||||||
ThemeWidget *rofi_configuration = NULL;
|
ThemeWidget *rofi_configuration = NULL;
|
||||||
|
|
||||||
/** Different sources of configuration. */
|
/** Different sources of configuration. */
|
||||||
const char *const ConfigSourceStr[] = {
|
const char *const ConfigSourceStr[] = {"Default", "File", "Rasi File",
|
||||||
"Default",
|
"Commandline", "Don't Display"};
|
||||||
"File",
|
|
||||||
"Rasi File",
|
|
||||||
"Commandline",
|
|
||||||
};
|
|
||||||
/** Enumerator of different sources of configuration. */
|
/** Enumerator of different sources of configuration. */
|
||||||
enum ConfigSource {
|
enum ConfigSource {
|
||||||
CONFIG_DEFAULT = 0,
|
CONFIG_DEFAULT = 0,
|
||||||
CONFIG_FILE = 1,
|
CONFIG_FILE = 1,
|
||||||
CONFIG_FILE_THEME = 2,
|
CONFIG_FILE_THEME = 2,
|
||||||
CONFIG_CMDLINE = 3
|
CONFIG_CMDLINE = 3,
|
||||||
|
CONFIG_NO_DISPLAY = 4
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
|
@ -346,7 +343,7 @@ static XrmOption xrmOptions[] = {
|
||||||
{.str = &config.theme},
|
{.str = &config.theme},
|
||||||
NULL,
|
NULL,
|
||||||
"New style theme file",
|
"New style theme file",
|
||||||
CONFIG_DEFAULT},
|
CONFIG_DEFAULT | CONFIG_NO_DISPLAY},
|
||||||
{xrm_Number,
|
{xrm_Number,
|
||||||
"max-history-size",
|
"max-history-size",
|
||||||
{.num = &config.max_history_size},
|
{.num = &config.max_history_size},
|
||||||
|
@ -466,12 +463,12 @@ static void config_parse_cmd_option(XrmOption *option) {
|
||||||
switch (option->type) {
|
switch (option->type) {
|
||||||
case xrm_Number:
|
case xrm_Number:
|
||||||
if (find_arg_uint(key, option->value.num) == TRUE) {
|
if (find_arg_uint(key, option->value.num) == TRUE) {
|
||||||
option->source = CONFIG_CMDLINE;
|
option->source = (option->source & ~3) | CONFIG_CMDLINE;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case xrm_SNumber:
|
case xrm_SNumber:
|
||||||
if (find_arg_int(key, option->value.snum) == TRUE) {
|
if (find_arg_int(key, option->value.snum) == TRUE) {
|
||||||
option->source = CONFIG_CMDLINE;
|
option->source = (option->source & ~3) | CONFIG_CMDLINE;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case xrm_String:
|
case xrm_String:
|
||||||
|
@ -480,25 +477,25 @@ static void config_parse_cmd_option(XrmOption *option) {
|
||||||
g_free(option->mem);
|
g_free(option->mem);
|
||||||
option->mem = NULL;
|
option->mem = NULL;
|
||||||
}
|
}
|
||||||
option->source = CONFIG_CMDLINE;
|
option->source = (option->source & ~3) | CONFIG_CMDLINE;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case xrm_Boolean:
|
case xrm_Boolean:
|
||||||
if (find_arg(key) >= 0) {
|
if (find_arg(key) >= 0) {
|
||||||
*(option->value.num) = TRUE;
|
*(option->value.num) = TRUE;
|
||||||
option->source = CONFIG_CMDLINE;
|
option->source = (option->source & ~3) | CONFIG_CMDLINE;
|
||||||
} else {
|
} else {
|
||||||
g_free(key);
|
g_free(key);
|
||||||
key = g_strdup_printf("-no-%s", option->name);
|
key = g_strdup_printf("-no-%s", option->name);
|
||||||
if (find_arg(key) >= 0) {
|
if (find_arg(key) >= 0) {
|
||||||
*(option->value.num) = FALSE;
|
*(option->value.num) = FALSE;
|
||||||
option->source = CONFIG_CMDLINE;
|
option->source = (option->source & ~3) | CONFIG_CMDLINE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case xrm_Char:
|
case xrm_Char:
|
||||||
if (find_arg_char(key, option->value.charc) == TRUE) {
|
if (find_arg_char(key, option->value.charc) == TRUE) {
|
||||||
option->source = CONFIG_CMDLINE;
|
option->source = (option->source & ~3) | CONFIG_CMDLINE;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
@ -597,7 +594,7 @@ static gboolean __config_parser_set_property(XrmOption *option,
|
||||||
|
|
||||||
// Memory
|
// Memory
|
||||||
(option)->mem = *(option->value.str);
|
(option)->mem = *(option->value.str);
|
||||||
option->source = CONFIG_FILE_THEME;
|
option->source = (option->source & ~3) | CONFIG_FILE_THEME;
|
||||||
} else if (option->type == xrm_Number) {
|
} else if (option->type == xrm_Number) {
|
||||||
if (p->type != P_INTEGER) {
|
if (p->type != P_INTEGER) {
|
||||||
*error =
|
*error =
|
||||||
|
@ -606,7 +603,7 @@ static gboolean __config_parser_set_property(XrmOption *option,
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
*(option->value.snum) = p->value.i;
|
*(option->value.snum) = p->value.i;
|
||||||
option->source = CONFIG_FILE_THEME;
|
option->source = (option->source & ~3) | CONFIG_FILE_THEME;
|
||||||
} else if (option->type == xrm_SNumber) {
|
} else if (option->type == xrm_SNumber) {
|
||||||
if (p->type != P_INTEGER) {
|
if (p->type != P_INTEGER) {
|
||||||
*error =
|
*error =
|
||||||
|
@ -615,7 +612,7 @@ static gboolean __config_parser_set_property(XrmOption *option,
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
*(option->value.num) = (unsigned int)(p->value.i);
|
*(option->value.num) = (unsigned int)(p->value.i);
|
||||||
option->source = CONFIG_FILE_THEME;
|
option->source = (option->source & ~3) | CONFIG_FILE_THEME;
|
||||||
} else if (option->type == xrm_Boolean) {
|
} else if (option->type == xrm_Boolean) {
|
||||||
if (p->type != P_BOOLEAN) {
|
if (p->type != P_BOOLEAN) {
|
||||||
*error =
|
*error =
|
||||||
|
@ -624,7 +621,7 @@ static gboolean __config_parser_set_property(XrmOption *option,
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
*(option->value.num) = (p->value.b);
|
*(option->value.num) = (p->value.b);
|
||||||
option->source = CONFIG_FILE_THEME;
|
option->source = (option->source & ~3) | CONFIG_FILE_THEME;
|
||||||
} else if (option->type == xrm_Char) {
|
} else if (option->type == xrm_Char) {
|
||||||
if (p->type != P_CHAR) {
|
if (p->type != P_CHAR) {
|
||||||
*error = g_strdup_printf(
|
*error = g_strdup_printf(
|
||||||
|
@ -633,7 +630,7 @@ static gboolean __config_parser_set_property(XrmOption *option,
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
*(option->value.charc) = (p->value.c);
|
*(option->value.charc) = (p->value.c);
|
||||||
option->source = CONFIG_FILE_THEME;
|
option->source = (option->source & ~3) | CONFIG_FILE_THEME;
|
||||||
} else {
|
} else {
|
||||||
// TODO add type
|
// TODO add type
|
||||||
*error = g_strdup_printf("Option: %s is not of a supported type: %s.",
|
*error = g_strdup_printf("Option: %s is not of a supported type: %s.",
|
||||||
|
@ -675,7 +672,6 @@ gboolean config_parse_set_property(const Property *p, char **error) {
|
||||||
//*error = g_strdup_printf("Option: %s is not found.", p->name);
|
//*error = g_strdup_printf("Option: %s is not found.", p->name);
|
||||||
g_warning("Option: %s is not found.", p->name);
|
g_warning("Option: %s is not found.", p->name);
|
||||||
|
|
||||||
|
|
||||||
for (GList *iter = g_list_first(extra_parsed_options); iter != NULL;
|
for (GList *iter = g_list_first(extra_parsed_options); iter != NULL;
|
||||||
iter = g_list_next(iter)) {
|
iter = g_list_next(iter)) {
|
||||||
if (g_strcmp0(((Property *)(iter->data))->name, p->name) == 0) {
|
if (g_strcmp0(((Property *)(iter->data))->name, p->name) == 0) {
|
||||||
|
@ -713,7 +709,7 @@ void config_xresource_free(void) {
|
||||||
}
|
}
|
||||||
|
|
||||||
static void config_parse_dump_config_option(FILE *out, XrmOption *option) {
|
static void config_parse_dump_config_option(FILE *out, XrmOption *option) {
|
||||||
if (option->type == xrm_Char || option->source == CONFIG_DEFAULT) {
|
if (option->type == xrm_Char || (option->source & 3) == CONFIG_DEFAULT) {
|
||||||
fprintf(out, "/*");
|
fprintf(out, "/*");
|
||||||
}
|
}
|
||||||
fprintf(out, "\t%s: ", option->name);
|
fprintf(out, "\t%s: ", option->name);
|
||||||
|
@ -747,7 +743,7 @@ static void config_parse_dump_config_option(FILE *out, XrmOption *option) {
|
||||||
}
|
}
|
||||||
|
|
||||||
fprintf(out, ";");
|
fprintf(out, ";");
|
||||||
if (option->type == xrm_Char || option->source == CONFIG_DEFAULT) {
|
if (option->type == xrm_Char || (option->source & 3) == CONFIG_DEFAULT) {
|
||||||
fprintf(out, "*/");
|
fprintf(out, "*/");
|
||||||
}
|
}
|
||||||
fprintf(out, "\n");
|
fprintf(out, "\n");
|
||||||
|
@ -764,12 +760,19 @@ void config_parse_dump_config_rasi_format(FILE *out, gboolean changes) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (!changes || xrmOptions[i].source != CONFIG_DEFAULT) {
|
if ((xrmOptions[i].source & CONFIG_NO_DISPLAY) == CONFIG_NO_DISPLAY) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
if (!changes || (xrmOptions[i].source & 3) != CONFIG_DEFAULT) {
|
||||||
config_parse_dump_config_option(out, &(xrmOptions[i]));
|
config_parse_dump_config_option(out, &(xrmOptions[i]));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for (unsigned int i = 0; i < num_extra_options; i++) {
|
for (unsigned int i = 0; i < num_extra_options; i++) {
|
||||||
if (!changes || extra_options[i].source != CONFIG_DEFAULT) {
|
if ((extra_options[i].source & CONFIG_NO_DISPLAY) == CONFIG_NO_DISPLAY) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
if (!changes || (extra_options[i].source & 3) != CONFIG_DEFAULT) {
|
||||||
|
|
||||||
config_parse_dump_config_option(out, &(extra_options[i]));
|
config_parse_dump_config_option(out, &(extra_options[i]));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -780,6 +783,10 @@ void config_parse_dump_config_rasi_format(FILE *out, gboolean changes) {
|
||||||
}
|
}
|
||||||
|
|
||||||
fprintf(out, "}\n");
|
fprintf(out, "}\n");
|
||||||
|
|
||||||
|
if (config.theme != NULL) {
|
||||||
|
fprintf(out, "@theme \"%s\"\r\n", config.theme);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void print_option_string(XrmOption *xo, int is_term) {
|
static void print_option_string(XrmOption *xo, int is_term) {
|
||||||
|
@ -790,12 +797,12 @@ static void print_option_string(XrmOption *xo, int is_term) {
|
||||||
printf("\t" color_italic "%s" color_reset,
|
printf("\t" color_italic "%s" color_reset,
|
||||||
(*(xo->value.str) == NULL) ? "(unset)" : (*(xo->value.str)));
|
(*(xo->value.str) == NULL) ? "(unset)" : (*(xo->value.str)));
|
||||||
printf(" " color_green "(%s)" color_reset "\n",
|
printf(" " color_green "(%s)" color_reset "\n",
|
||||||
ConfigSourceStr[xo->source]);
|
ConfigSourceStr[xo->source & 3]);
|
||||||
} else {
|
} else {
|
||||||
printf("\t-%s [string]%-*c%s\n", xo->name, 30 - l, ' ', xo->comment);
|
printf("\t-%s [string]%-*c%s\n", xo->name, 30 - l, ' ', xo->comment);
|
||||||
printf("\t\t%s",
|
printf("\t\t%s",
|
||||||
(*(xo->value.str) == NULL) ? "(unset)" : (*(xo->value.str)));
|
(*(xo->value.str) == NULL) ? "(unset)" : (*(xo->value.str)));
|
||||||
printf(" (%s)\n", ConfigSourceStr[xo->source]);
|
printf(" (%s)\n", ConfigSourceStr[xo->source & 3]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
static void print_option_number(XrmOption *xo, int is_term) {
|
static void print_option_number(XrmOption *xo, int is_term) {
|
||||||
|
@ -805,11 +812,11 @@ static void print_option_number(XrmOption *xo, int is_term) {
|
||||||
30 - l, ' ', xo->comment);
|
30 - l, ' ', xo->comment);
|
||||||
printf("\t" color_italic "%u" color_reset, *(xo->value.num));
|
printf("\t" color_italic "%u" color_reset, *(xo->value.num));
|
||||||
printf(" " color_green "(%s)" color_reset "\n",
|
printf(" " color_green "(%s)" color_reset "\n",
|
||||||
ConfigSourceStr[xo->source]);
|
ConfigSourceStr[xo->source & 3]);
|
||||||
} else {
|
} else {
|
||||||
printf("\t-%s [number]%-*c%s\n", xo->name, 30 - l, ' ', xo->comment);
|
printf("\t-%s [number]%-*c%s\n", xo->name, 30 - l, ' ', xo->comment);
|
||||||
printf("\t\t%u", *(xo->value.num));
|
printf("\t\t%u", *(xo->value.num));
|
||||||
printf(" (%s)\n", ConfigSourceStr[xo->source]);
|
printf(" (%s)\n", ConfigSourceStr[xo->source & 3]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
static void print_option_snumber(XrmOption *xo, int is_term) {
|
static void print_option_snumber(XrmOption *xo, int is_term) {
|
||||||
|
@ -819,11 +826,11 @@ static void print_option_snumber(XrmOption *xo, int is_term) {
|
||||||
30 - l, ' ', xo->comment);
|
30 - l, ' ', xo->comment);
|
||||||
printf("\t" color_italic "%d" color_reset, *(xo->value.snum));
|
printf("\t" color_italic "%d" color_reset, *(xo->value.snum));
|
||||||
printf(" " color_green "(%s)" color_reset "\n",
|
printf(" " color_green "(%s)" color_reset "\n",
|
||||||
ConfigSourceStr[xo->source]);
|
ConfigSourceStr[xo->source & 3]);
|
||||||
} else {
|
} else {
|
||||||
printf("\t-%s [number]%-*c%s\n", xo->name, 30 - l, ' ', xo->comment);
|
printf("\t-%s [number]%-*c%s\n", xo->name, 30 - l, ' ', xo->comment);
|
||||||
printf("\t\t%d", *(xo->value.snum));
|
printf("\t\t%d", *(xo->value.snum));
|
||||||
printf(" (%s)\n", ConfigSourceStr[xo->source]);
|
printf(" (%s)\n", ConfigSourceStr[xo->source & 3]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
static void print_option_char(XrmOption *xo, int is_term) {
|
static void print_option_char(XrmOption *xo, int is_term) {
|
||||||
|
@ -833,11 +840,11 @@ static void print_option_char(XrmOption *xo, int is_term) {
|
||||||
30 - l, ' ', xo->comment);
|
30 - l, ' ', xo->comment);
|
||||||
printf("\t" color_italic "%c" color_reset, *(xo->value.charc));
|
printf("\t" color_italic "%c" color_reset, *(xo->value.charc));
|
||||||
printf(" " color_green "(%s)" color_reset "\n",
|
printf(" " color_green "(%s)" color_reset "\n",
|
||||||
ConfigSourceStr[xo->source]);
|
ConfigSourceStr[xo->source & 3]);
|
||||||
} else {
|
} else {
|
||||||
printf("\t-%s [character]%-*c%s\n", xo->name, 30 - l, ' ', xo->comment);
|
printf("\t-%s [character]%-*c%s\n", xo->name, 30 - l, ' ', xo->comment);
|
||||||
printf("\t\t%c", *(xo->value.charc));
|
printf("\t\t%c", *(xo->value.charc));
|
||||||
printf(" (%s)\n", ConfigSourceStr[xo->source]);
|
printf(" (%s)\n", ConfigSourceStr[xo->source & 3]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
static void print_option_boolean(XrmOption *xo, int is_term) {
|
static void print_option_boolean(XrmOption *xo, int is_term) {
|
||||||
|
@ -848,15 +855,18 @@ static void print_option_boolean(XrmOption *xo, int is_term) {
|
||||||
printf("\t" color_italic "%s" color_reset,
|
printf("\t" color_italic "%s" color_reset,
|
||||||
(*(xo->value.snum)) ? "True" : "False");
|
(*(xo->value.snum)) ? "True" : "False");
|
||||||
printf(" " color_green "(%s)" color_reset "\n",
|
printf(" " color_green "(%s)" color_reset "\n",
|
||||||
ConfigSourceStr[xo->source]);
|
ConfigSourceStr[xo->source & 3]);
|
||||||
} else {
|
} else {
|
||||||
printf("\t-[no-]%s %-*c%s\n", xo->name, 33 - l, ' ', xo->comment);
|
printf("\t-[no-]%s %-*c%s\n", xo->name, 33 - l, ' ', xo->comment);
|
||||||
printf("\t\t%s", (*(xo->value.snum)) ? "True" : "False");
|
printf("\t\t%s", (*(xo->value.snum)) ? "True" : "False");
|
||||||
printf(" (%s)\n", ConfigSourceStr[xo->source]);
|
printf(" (%s)\n", ConfigSourceStr[xo->source & 3]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void print_option(XrmOption *xo, int is_term) {
|
static void print_option(XrmOption *xo, int is_term) {
|
||||||
|
if ((xo->source & CONFIG_NO_DISPLAY) == CONFIG_NO_DISPLAY) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
switch (xo->type) {
|
switch (xo->type) {
|
||||||
case xrm_String:
|
case xrm_String:
|
||||||
print_option_string(xo, is_term);
|
print_option_string(xo, is_term);
|
||||||
|
|
Loading…
Reference in a new issue