diff options
-rw-r--r-- | src/fe-common/core/themes.c | 49 |
1 files changed, 35 insertions, 14 deletions
diff --git a/src/fe-common/core/themes.c b/src/fe-common/core/themes.c index 73e5e094..d283376c 100644 --- a/src/fe-common/core/themes.c +++ b/src/fe-common/core/themes.c @@ -814,36 +814,57 @@ static void cmd_format(const char *data) cmd_params_free(free_arg); } -static void module_save(const char *module, MODULE_THEME_REC *rec, CONFIG_NODE *fnode) +static void module_save(const char *module, MODULE_THEME_REC *rec, + CONFIG_REC *config) { - CONFIG_NODE *node; + CONFIG_NODE *fnode, *node; FORMAT_REC *formats; int n; - formats = g_hash_table_lookup(default_formats, rec->name); + formats = g_hash_table_lookup(default_formats, rec->name); if (formats == NULL) return; + fnode = config_node_traverse(config, "formats", TRUE); + node = config_node_section(fnode, rec->name, NODE_TYPE_BLOCK); for (n = 0; formats[n].def != NULL; n++) { - if (rec->formats[n] != NULL) - iconfig_node_set_str(node, formats[n].tag, rec->formats[n]); - } + if (rec->formats[n] != NULL) { + config_node_set_str(config, node, formats[n].tag, + rec->formats[n]); + } + } + + if (node->value == NULL) { + /* not modified, don't keep the empty section */ + config_node_remove(config, fnode, node); + if (fnode->value == NULL) + config_node_remove(config, config->mainnode, fnode); + } } static void theme_save(THEME_REC *theme) { CONFIG_REC *config; - CONFIG_NODE *fnode; char *path; int ok; - config = config_open(theme->path, 0660); - if (config == NULL) return; - - config_parse(config); - - fnode = config_node_traverse(config, "formats", TRUE); - g_hash_table_foreach(theme->modules, (GHFunc) module_save, fnode); + config = config_open(theme->path, -1); + if (config != NULL) + config_parse(config); + else { + if (g_strcasecmp(theme->name, "default") == 0) { + config = config_open(NULL, -1); + config_parse_data(config, default_theme, "internal"); + config_change_file_name(config, theme->path, 0660); + } else { + config = config_open(theme->path, 0660); + if (config == NULL) + return; + config_parse(config); + } + } + + g_hash_table_foreach(theme->modules, (GHFunc) module_save, config); ok = TRUE; path = g_strdup(theme->path); |