X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~mdw/git/disorder/blobdiff_plain/e1e3ef08ef3419f4aabcfb3f45ab49a78000cdb7..5f624baebe43889bb2810720cb9cc6d0812f49cb:/lib/configuration.c diff --git a/lib/configuration.c b/lib/configuration.c index 17f9ec7..469804d 100644 --- a/lib/configuration.c +++ b/lib/configuration.c @@ -66,6 +66,12 @@ */ char *configfile; +/** @brief Path to user's config file + * + * set_configfile() sets the default if it is null. + */ +char *userconfigfile; + /** @brief Read user configuration * * If clear, the user-specific configuration is not read. @@ -1451,10 +1457,20 @@ char *config_get_file2(struct config *c, const char *name) { /** @brief Set the default configuration file */ static void set_configfile(void) { + char *t; + #if !_WIN32 - if(!configfile) - byte_xasprintf(&configfile, "%s/config", pkgconfdir); + if(!configfile) { + configfile = getenv("DISORDER_CONFIG"); + if(!configfile) + byte_xasprintf(&configfile, "%s/config", pkgconfdir); + } #endif + if(!userconfigfile && config_per_user) { + if((t = getenv("DISORDER_USERCONFIG"))) userconfigfile = xstrdup(t); + else if(!(userconfigfile = profile_filename("passwd"))) + disorder_fatal(0, "failed to find user profile directory"); + } } /** @brief Free a configuration object @@ -1604,11 +1620,9 @@ int config_read(int server, xfree(privconf); #endif /* if we have a password file, read it */ - if((privconf = config_userconf()) - && access(privconf, F_OK) == 0 - && config_include(c, privconf)) + if(access(userconfigfile, F_OK) == 0 + && config_include(c, userconfigfile)) return -1; - xfree(privconf); } /* install default namepart and transform settings */ config_postdefaults(c, server); @@ -1663,24 +1677,22 @@ char *config_private(void) { #else char *s; + if((s = getenv("DISORDER_PRIVCONFIG"))) return xstrdup(s); set_configfile(); byte_xasprintf(&s, "%s.private", configfile); return s; #endif } -/** @brief Return the path to user's personal configuration file */ -char *config_userconf(void) { - return profile_filename("passwd"); -} - #if !_WIN32 /** @brief Return the path to user-specific system configuration */ char *config_usersysconf(const struct passwd *pw) { char *s; set_configfile(); - if(!strchr(pw->pw_name, '/')) { + if((s = getenv("DISORDER_USERCONFIG_SYS"))) + return xstrdup(s); + else if(!strchr(pw->pw_name, '/')) { byte_xasprintf(&s, "%s.%s", configfile, pw->pw_name); return s; } else