X-Git-Url: http://git.maemo.org/git/?p=browser-switch;a=blobdiff_plain;f=config.c;h=033ac0b2b0d38e015c38a0151eea487a45d8b967;hp=289374b2b29eda998a1a80baca17a85554cfdaa1;hb=refs%2Fheads%2Ffremantle-microb-improvements;hpb=38de05f23e8556012be028c25f7a7a1571e34e1a diff --git a/config.c b/config.c index 289374b..033ac0b 100644 --- a/config.c +++ b/config.c @@ -33,6 +33,7 @@ struct swb_config_option swb_config_options[] = { { "default_browser", SWB_CONFIG_OPT_STRING, SWB_CONFIG_DEFAULT_BROWSER_SET }, { "other_browser_cmd", SWB_CONFIG_OPT_STRING, SWB_CONFIG_OTHER_BROWSER_CMD_SET }, { "logging", SWB_CONFIG_OPT_STRING, SWB_CONFIG_LOGGING_SET }, + { "autostart_microb", SWB_CONFIG_OPT_INT, SWB_CONFIG_AUTOSTART_MICROB_SET }, { NULL, 0, 0 }, }; @@ -43,6 +44,7 @@ static struct swb_config swb_config_defaults = { .default_browser = "microb", .other_browser_cmd = NULL, .logging = "stdout", + .autostart_microb = -1, }; @@ -56,6 +58,7 @@ void swb_config_copy(struct swb_config *dst, struct swb_config *src) { dst->entries[1] = &(dst->default_browser); dst->entries[2] = &(dst->other_browser_cmd); dst->entries[3] = &(dst->logging); + dst->entries[4] = &(dst->autostart_microb); dst->flags = src->flags; @@ -63,6 +66,7 @@ void swb_config_copy(struct swb_config *dst, struct swb_config *src) { dst->default_browser = src->default_browser; dst->other_browser_cmd = src->other_browser_cmd; dst->logging = src->logging; + dst->autostart_microb = src->autostart_microb; } /* Initialize a swb_config struct with configuration defaults */ @@ -73,22 +77,24 @@ void swb_config_init(struct swb_config *cfg) { /* Free all heap memory used in an swb_config struct This MUST NOT be done if any of the strings are being used elsewhere! */ void swb_config_free(struct swb_config *cfg) { + int i; + if (!cfg) return; if (!(cfg->flags & SWB_CONFIG_INITIALIZED)) return; - if (cfg->flags & SWB_CONFIG_DEFAULT_BROWSER_SET) { - free(cfg->default_browser); - cfg->default_browser = NULL; - } - if (cfg->flags & SWB_CONFIG_OTHER_BROWSER_CMD_SET) { - free(cfg->other_browser_cmd); - cfg->other_browser_cmd = NULL; - } - if (cfg->flags & SWB_CONFIG_LOGGING_SET) { - free(cfg->logging); - cfg->logging = NULL; + for (i = 0; swb_config_options[i].name; ++i) { + if (cfg->flags & swb_config_options[i].set_mask) { + switch (swb_config_options[i].type) { + case SWB_CONFIG_OPT_STRING: + free(*(char **)cfg->entries[i]); + *(char **)cfg->entries[i] = NULL; + break; + default: + break; + } + } } cfg->flags = 0;