waf: use PYTHONARCHDIR for installing python shared libs
[samba.git] / source4 / dynconfig / dynconfig.c
1 /* 
2    Unix SMB/CIFS implementation.
3    Copyright (C) 2001 by Martin Pool <mbp@samba.org>
4    Copyright (C) Jim McDonough (jmcd@us.ibm.com)  2003.
5    Copyright (C) Stefan Metzmacher      2003
6    
7    This program is free software; you can redistribute it and/or modify
8    it under the terms of the GNU General Public License as published by
9    the Free Software Foundation; either version 3 of the License, or
10    (at your option) any later version.
11    
12    This program is distributed in the hope that it will be useful,
13    but WITHOUT ANY WARRANTY; without even the implied warranty of
14    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15    GNU General Public License for more details.
16    
17    You should have received a copy of the GNU General Public License
18    along with this program.  If not, see <http://www.gnu.org/licenses/>.
19 */
20
21 #include "includes.h"
22
23 /**
24  * @file dynconfig.c
25  *
26  * @brief Global configurations, initialized to configured defaults.
27  *
28  * This file should be the only file that depends on path
29  * configuration (--prefix, etc), so that if ./configure is re-run,
30  * all programs will be appropriately updated.  Everything else in
31  * Samba should import extern variables from here, rather than relying
32  * on preprocessor macros.
33  *
34  * Eventually some of these may become even more variable, so that
35  * they can for example consistently be set across the whole of Samba
36  * by command-line parameters, config file entries, or environment
37  * variables.
38  *
39  * @todo Perhaps eventually these should be merged into the parameter
40  * table?  There's kind of a chicken-and-egg situation there...
41  **/
42
43 #include "dynconfig.h"
44
45 #define DEFINE_DYN_CONFIG_PARAM(name) \
46 const char *dyn_##name = name; \
47 \
48  const char *get_dyn_##name(void) \
49 {\
50         if (dyn_##name == NULL) {\
51                 return name;\
52         }\
53         return dyn_##name;\
54 }\
55 \
56  const char *set_dyn_##name(const char *newpath) \
57 {\
58         if (dyn_##name) {\
59                 free(discard_const(dyn_##name));        \
60         }\
61         dyn_##name = strdup(newpath);\
62         return dyn_##name;\
63 }\
64  bool is_default_dyn_##name(void) \
65 {\
66         return (dyn_##name == NULL);\
67 }
68
69 /* these are in common with s3 */
70 DEFINE_DYN_CONFIG_PARAM(SBINDIR)
71 DEFINE_DYN_CONFIG_PARAM(BINDIR)
72 DEFINE_DYN_CONFIG_PARAM(SWATDIR)
73 DEFINE_DYN_CONFIG_PARAM(CONFIGFILE) /**< Location of smb.conf file. **/
74 DEFINE_DYN_CONFIG_PARAM(LOGFILEBASE) /** Log file directory. **/
75 DEFINE_DYN_CONFIG_PARAM(LMHOSTSFILE) /** Statically configured LanMan hosts. **/
76 DEFINE_DYN_CONFIG_PARAM(CODEPAGEDIR)
77 DEFINE_DYN_CONFIG_PARAM(LIBDIR)
78 DEFINE_DYN_CONFIG_PARAM(MODULESDIR)
79 DEFINE_DYN_CONFIG_PARAM(SHLIBEXT)
80 DEFINE_DYN_CONFIG_PARAM(LOCKDIR)
81 DEFINE_DYN_CONFIG_PARAM(STATEDIR) /** Persistent state files. Default LOCKDIR */
82 DEFINE_DYN_CONFIG_PARAM(CACHEDIR) /** Temporary cache files. Default LOCKDIR */
83 DEFINE_DYN_CONFIG_PARAM(PIDDIR)
84 DEFINE_DYN_CONFIG_PARAM(NCALRPCDIR)
85 DEFINE_DYN_CONFIG_PARAM(SMB_PASSWD_FILE)
86 DEFINE_DYN_CONFIG_PARAM(PRIVATE_DIR)
87
88 /* these are not in s3 */
89 DEFINE_DYN_CONFIG_PARAM(DATADIR)
90 DEFINE_DYN_CONFIG_PARAM(SETUPDIR)
91 DEFINE_DYN_CONFIG_PARAM(WINBINDD_SOCKET_DIR)
92 DEFINE_DYN_CONFIG_PARAM(WINBINDD_PRIVILEGED_SOCKET_DIR)
93 DEFINE_DYN_CONFIG_PARAM(NTP_SIGND_SOCKET_DIR)
94 DEFINE_DYN_CONFIG_PARAM(PYTHONDIR)
95 DEFINE_DYN_CONFIG_PARAM(PYTHONARCHDIR)
96 DEFINE_DYN_CONFIG_PARAM(SCRIPTSBINDIR)