/* Unix SMB/CIFS implementation. Copyright (C) 2001 by Martin Pool Copyright (C) 2003 by Jim McDonough This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see . */ #include "includes.h" /** * @file dynconfig.c * * @brief Global configurations, initialized to configured defaults. * * This file should be the only file that depends on path * configuration (--prefix, etc), so that if ./configure is re-run, * all programs will be appropriately updated. Everything else in * Samba should import extern variables from here, rather than relying * on preprocessor macros. * * Eventually some of these may become even more variable, so that * they can for example consistently be set across the whole of Samba * by command-line parameters, config file entries, or environment * variables. * * @todo Perhaps eventually these should be merged into the parameter * table? There's kind of a chicken-and-egg situation there... **/ char const *dyn_SBINDIR = SBINDIR, *dyn_BINDIR = BINDIR, *dyn_SWATDIR = SWATDIR; /* JRA - FIXME - these should be dynamic char * */ char dyn_CONFIGFILE[1024] = CONFIGFILE; /**< Location of smb.conf file. **/ /** Log file directory. **/ char dyn_LOGFILEBASE[1024] = LOGFILEBASE; /** Statically configured LanMan hosts. **/ char dyn_LMHOSTSFILE[1024] = LMHOSTSFILE; /** * @brief Samba data directory. * * @sa data_path() to get the path to a file inside the CODEPAGEDIR. **/ char dyn_CODEPAGEDIR[1024] = CODEPAGEDIR; /** * @brief Samba library directory. * * @sa lib_path() to get the path to a file inside the LIBDIR. **/ char dyn_LIBDIR[1024] = LIBDIR; fstring dyn_SHLIBEXT = SHLIBEXT; /** * @brief Directory holding lock files. * * Not writable, but used to set a default in the parameter table. **/ char dyn_LOCKDIR[1024] = LOCKDIR; char dyn_PIDDIR[1024] = PIDDIR; char dyn_SMB_PASSWD_FILE[1024] = SMB_PASSWD_FILE; char dyn_PRIVATE_DIR[1024] = PRIVATE_DIR; /* In non-FHS mode, these should be configurable using 'lock dir ='; but in FHS mode, they are their own directory. Implement as wrapper functions so that everything can still be kept in dynconfig.c. */ char *dyn_STATEDIR(void) { #ifdef FHS_COMPATIBLE return STATEDIR; #else return lp_lockdir(); #endif } char *dyn_CACHEDIR(void) { #ifdef FHS_COMPATIBLE return CACHEDIR; #else return lp_lockdir(); #endif }