diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/conf.c | 27 | ||||
-rw-r--r-- | src/main.c | 14 |
2 files changed, 20 insertions, 21 deletions
@@ -315,6 +315,7 @@ int conf_configure(void) goto out; } + conf_obj = mem_deref(conf_obj); err = conf_alloc(&conf_obj, file); if (err) goto out; @@ -324,7 +325,6 @@ int conf_configure(void) goto out; out: - conf_obj = mem_deref(conf_obj); return err; } @@ -333,23 +333,13 @@ int conf_configure(void) * Load all modules from config file * * @return 0 if success, otherwise errorcode + * + * @note conf_configure must be called first */ int conf_modules(void) { - char path[256], file[256]; int err; - err = conf_path_get(path, sizeof(path)); - if (err) - return err; - - if (re_snprintf(file, sizeof(file), "%s/config", path) < 0) - return ENOMEM; - - err = conf_alloc(&conf_obj, file); - if (err) - goto out; - err = module_init(conf_obj); if (err) { warning("conf: configure module parse error (%m)\n", err); @@ -364,7 +354,6 @@ int conf_modules(void) #endif out: - conf_obj = mem_deref(conf_obj); return err; } @@ -378,5 +367,15 @@ int conf_modules(void) */ struct conf *conf_cur(void) { + if (!conf_obj) { + warning("conf: no config object\n"); + } return conf_obj; } + + +void conf_close(void) +{ + mod_close(); + conf_obj = mem_deref(conf_obj); +} @@ -141,6 +141,12 @@ int main(int argc, char *argv[]) (void)argv; #endif + err = conf_configure(); + if (err) { + warning("main: configure failed: %m\n", err); + goto out; + } + /* NOTE: must be done after all arguments are processed */ if (modc) { size_t i; @@ -158,12 +164,6 @@ int main(int argc, char *argv[]) } } - err = conf_configure(); - if (err) { - warning("main: configure failed: %m\n", err); - goto out; - } - /* Initialise User Agents */ err = ua_init("baresip v" BARESIP_VERSION " (" ARCH "/" OS ")", true, true, true, prefer_ipv6); @@ -205,7 +205,7 @@ int main(int argc, char *argv[]) ua_stop_all(true); ua_close(); - mod_close(); + conf_close(); libre_close(); |