blob: b73503d296c82ff7d149825a82efb539ae851cdb [file] [log] [blame]
Fred Drake70b014d2001-07-18 18:39:56 +00001"""Provide access to Python's configuration information. The specific
2configuration variables available depend heavily on the platform and
3configuration. The values may be retrieved using
4get_config_var(name), and the list of variables is available via
5get_config_vars().keys(). Additional convenience functions are also
6available.
Greg Ward1190ee31998-12-18 23:46:33 +00007
8Written by: Fred L. Drake, Jr.
9Email: <fdrake@acm.org>
Greg Ward1190ee31998-12-18 23:46:33 +000010"""
11
Greg Ward9ddaaa11999-01-06 14:46:06 +000012import os
13import re
Tarek Ziadé36797272010-07-22 12:50:05 +000014import sys
Greg Ward1190ee31998-12-18 23:46:33 +000015
Tarek Ziadé36797272010-07-22 12:50:05 +000016from .errors import DistutilsPlatformError
Greg Warda0ca3f22000-02-02 00:05:14 +000017
Tarek Ziadé36797272010-07-22 12:50:05 +000018# These are needed in a couple of spots, so just compute them once.
19PREFIX = os.path.normpath(sys.prefix)
20EXEC_PREFIX = os.path.normpath(sys.exec_prefix)
Vinay Sajip7ded1f02012-05-26 03:45:29 +010021BASE_PREFIX = os.path.normpath(sys.base_prefix)
22BASE_EXEC_PREFIX = os.path.normpath(sys.base_exec_prefix)
Fred Drakec1ee39a2000-03-09 15:54:52 +000023
Tarek Ziadé36797272010-07-22 12:50:05 +000024# Path to the base directory of the project. On Windows the binary may
25# live in project/PCBuild9. If we're dealing with an x64 Windows build,
26# it'll live in project/PCbuild/amd64.
doko@python.org97313302013-01-25 14:33:33 +010027# set for cross builds
28if "_PYTHON_PROJECT_BASE" in os.environ:
29 project_base = os.path.abspath(os.environ["_PYTHON_PROJECT_BASE"])
30else:
31 project_base = os.path.dirname(os.path.abspath(sys.executable))
Tarek Ziadé36797272010-07-22 12:50:05 +000032if os.name == "nt" and "pcbuild" in project_base[-8:].lower():
33 project_base = os.path.abspath(os.path.join(project_base, os.path.pardir))
34# PC/VS7.1
35if os.name == "nt" and "\\pc\\v" in project_base[-10:].lower():
36 project_base = os.path.abspath(os.path.join(project_base, os.path.pardir,
37 os.path.pardir))
38# PC/AMD64
39if os.name == "nt" and "\\pcbuild\\amd64" in project_base[-14:].lower():
40 project_base = os.path.abspath(os.path.join(project_base, os.path.pardir,
41 os.path.pardir))
Tarek Ziadé8b441d02010-01-29 11:46:31 +000042
Tarek Ziadé36797272010-07-22 12:50:05 +000043# python_build: (Boolean) if true, we're either building Python or
44# building an extension with an un-installed Python, so we use
45# different (hard-wired) directories.
46# Setup.local is available for Makefile builds including VPATH builds,
47# Setup.dist is available on Windows
Vinay Sajip7ded1f02012-05-26 03:45:29 +010048def _is_python_source_dir(d):
Tarek Ziadé36797272010-07-22 12:50:05 +000049 for fn in ("Setup.dist", "Setup.local"):
Vinay Sajip7ded1f02012-05-26 03:45:29 +010050 if os.path.isfile(os.path.join(d, "Modules", fn)):
Tarek Ziadé36797272010-07-22 12:50:05 +000051 return True
52 return False
Vinay Sajip7ded1f02012-05-26 03:45:29 +010053_sys_home = getattr(sys, '_home', None)
Vinay Sajip42211422012-05-26 20:36:12 +010054if _sys_home and os.name == 'nt' and \
55 _sys_home.lower().endswith(('pcbuild', 'pcbuild\\amd64')):
Vinay Sajip7ded1f02012-05-26 03:45:29 +010056 _sys_home = os.path.dirname(_sys_home)
Vinay Sajip7e203492012-05-27 17:30:09 +010057 if _sys_home.endswith('pcbuild'): # must be amd64
58 _sys_home = os.path.dirname(_sys_home)
Vinay Sajip7ded1f02012-05-26 03:45:29 +010059def _python_build():
60 if _sys_home:
61 return _is_python_source_dir(_sys_home)
62 return _is_python_source_dir(project_base)
Christian Heimes2202f872008-02-06 14:31:34 +000063python_build = _python_build()
Fred Drakec916cdc2001-08-02 20:03:12 +000064
Barry Warsaw14d98ac2010-11-24 19:43:47 +000065# Calculate the build qualifier flags if they are defined. Adding the flags
66# to the include and lib directories only makes sense for an installation, not
67# an in-source build.
68build_flags = ''
69try:
70 if not python_build:
71 build_flags = sys.abiflags
72except AttributeError:
73 # It's not a configure-based build, so the sys module doesn't have
74 # this attribute, which is fine.
75 pass
76
Tarek Ziadé36797272010-07-22 12:50:05 +000077def get_python_version():
78 """Return a string containing the major and minor Python version,
79 leaving off the patchlevel. Sample return values could be '1.5'
80 or '2.2'.
81 """
82 return sys.version[:3]
Tarek Ziadéedacea32010-01-29 11:41:03 +000083
Tarek Ziadé36797272010-07-22 12:50:05 +000084
85def get_python_inc(plat_specific=0, prefix=None):
86 """Return the directory containing installed Python header files.
Fred Drakec1ee39a2000-03-09 15:54:52 +000087
88 If 'plat_specific' is false (the default), this is the path to the
89 non-platform-specific header files, i.e. Python.h and so on;
90 otherwise, this is the path to platform-specific header files
Martin v. Löwis4f1cd8b2001-07-26 13:41:06 +000091 (namely pyconfig.h).
Fred Drakec1ee39a2000-03-09 15:54:52 +000092
Vinay Sajip7ded1f02012-05-26 03:45:29 +010093 If 'prefix' is supplied, use it instead of sys.base_prefix or
94 sys.base_exec_prefix -- i.e., ignore 'plat_specific'.
Fred Drakeb94b8492001-12-06 20:51:35 +000095 """
Tarek Ziadé36797272010-07-22 12:50:05 +000096 if prefix is None:
Vinay Sajip7ded1f02012-05-26 03:45:29 +010097 prefix = plat_specific and BASE_EXEC_PREFIX or BASE_PREFIX
Tarek Ziadé36797272010-07-22 12:50:05 +000098 if os.name == "posix":
99 if python_build:
Vinay Sajipae7d7fa2010-09-20 10:29:54 +0000100 # Assume the executable is in the build directory. The
101 # pyconfig.h file should be in the same directory. Since
102 # the build directory may not be the source directory, we
103 # must use "srcdir" from the makefile to find the "Include"
104 # directory.
doko@python.org97313302013-01-25 14:33:33 +0100105 base = _sys_home or project_base
Vinay Sajipae7d7fa2010-09-20 10:29:54 +0000106 if plat_specific:
107 return base
Vinay Sajip048b0632012-07-16 18:24:55 +0100108 if _sys_home:
109 incdir = os.path.join(_sys_home, get_config_var('AST_H_DIR'))
Vinay Sajipae7d7fa2010-09-20 10:29:54 +0000110 else:
Vinay Sajip048b0632012-07-16 18:24:55 +0100111 incdir = os.path.join(get_config_var('srcdir'), 'Include')
112 return os.path.normpath(incdir)
Barry Warsaw14d98ac2010-11-24 19:43:47 +0000113 python_dir = 'python' + get_python_version() + build_flags
114 return os.path.join(prefix, "include", python_dir)
Tarek Ziadé36797272010-07-22 12:50:05 +0000115 elif os.name == "nt":
116 return os.path.join(prefix, "include")
Tarek Ziadé36797272010-07-22 12:50:05 +0000117 elif os.name == "os2":
118 return os.path.join(prefix, "Include")
Greg Ward7d73b9e2000-03-09 03:16:05 +0000119 else:
Tarek Ziadé36797272010-07-22 12:50:05 +0000120 raise DistutilsPlatformError(
121 "I don't know where Python installs its C header files "
122 "on platform '%s'" % os.name)
Greg Ward7d73b9e2000-03-09 03:16:05 +0000123
124
Tarek Ziadé36797272010-07-22 12:50:05 +0000125def get_python_lib(plat_specific=0, standard_lib=0, prefix=None):
126 """Return the directory containing the Python library (standard or
Fred Drakec1ee39a2000-03-09 15:54:52 +0000127 site additions).
Greg Ward7d73b9e2000-03-09 03:16:05 +0000128
Fred Drakec1ee39a2000-03-09 15:54:52 +0000129 If 'plat_specific' is true, return the directory containing
130 platform-specific modules, i.e. any module from a non-pure-Python
131 module distribution; otherwise, return the platform-shared library
132 directory. If 'standard_lib' is true, return the directory
133 containing standard Python library modules; otherwise, return the
134 directory for site-specific modules.
135
Vinay Sajip7ded1f02012-05-26 03:45:29 +0100136 If 'prefix' is supplied, use it instead of sys.base_prefix or
137 sys.base_exec_prefix -- i.e., ignore 'plat_specific'.
Fred Drakec1ee39a2000-03-09 15:54:52 +0000138 """
Tarek Ziadé36797272010-07-22 12:50:05 +0000139 if prefix is None:
Vinay Sajip7ded1f02012-05-26 03:45:29 +0100140 if standard_lib:
141 prefix = plat_specific and BASE_EXEC_PREFIX or BASE_PREFIX
142 else:
143 prefix = plat_specific and EXEC_PREFIX or PREFIX
Tarek Ziadé36797272010-07-22 12:50:05 +0000144
145 if os.name == "posix":
146 libpython = os.path.join(prefix,
147 "lib", "python" + get_python_version())
148 if standard_lib:
149 return libpython
Greg Ward7d73b9e2000-03-09 03:16:05 +0000150 else:
Tarek Ziadé36797272010-07-22 12:50:05 +0000151 return os.path.join(libpython, "site-packages")
152 elif os.name == "nt":
153 if standard_lib:
154 return os.path.join(prefix, "Lib")
Marc-André Lemburg2544f512002-01-31 18:56:00 +0000155 else:
Tarek Ziadé36797272010-07-22 12:50:05 +0000156 if get_python_version() < "2.2":
157 return prefix
158 else:
159 return os.path.join(prefix, "Lib", "site-packages")
Tarek Ziadé36797272010-07-22 12:50:05 +0000160 elif os.name == "os2":
161 if standard_lib:
162 return os.path.join(prefix, "Lib")
163 else:
164 return os.path.join(prefix, "Lib", "site-packages")
Greg Ward7d73b9e2000-03-09 03:16:05 +0000165 else:
Tarek Ziadé36797272010-07-22 12:50:05 +0000166 raise DistutilsPlatformError(
167 "I don't know where Python installs its library "
168 "on platform '%s'" % os.name)
169
Ned Deilycbfb9a52012-06-23 16:02:19 -0700170
Tarek Ziadé36797272010-07-22 12:50:05 +0000171
172def customize_compiler(compiler):
173 """Do any platform-specific customization of a CCompiler instance.
174
175 Mainly needed on Unix, so we can plug in the information that
176 varies across Unices and is stored in Python's Makefile.
177 """
178 if compiler.compiler_type == "unix":
Ned Deilydf8aa2b2012-07-21 05:36:30 -0700179 if sys.platform == "darwin":
180 # Perform first-time customization of compiler-related
181 # config vars on OS X now that we know we need a compiler.
182 # This is primarily to support Pythons from binary
183 # installers. The kind and paths to build tools on
184 # the user system may vary significantly from the system
185 # that Python itself was built on. Also the user OS
186 # version and build tools may not support the same set
187 # of CPU architectures for universal builds.
188 global _config_vars
189 if not _config_vars.get('CUSTOMIZED_OSX_COMPILER', ''):
190 import _osx_support
191 _osx_support.customize_compiler(_config_vars)
192 _config_vars['CUSTOMIZED_OSX_COMPILER'] = 'True'
193
doko@ubuntu.comd5537d02013-03-21 13:21:49 -0700194 (cc, cxx, opt, cflags, ccshared, ldshared, shlib_suffix, ar, ar_flags) = \
Tarek Ziadé36797272010-07-22 12:50:05 +0000195 get_config_vars('CC', 'CXX', 'OPT', 'CFLAGS',
doko@ubuntu.comd5537d02013-03-21 13:21:49 -0700196 'CCSHARED', 'LDSHARED', 'SHLIB_SUFFIX', 'AR', 'ARFLAGS')
Tarek Ziadé36797272010-07-22 12:50:05 +0000197
Ned Deily99377482012-02-10 13:01:08 +0100198 newcc = None
Tarek Ziadé36797272010-07-22 12:50:05 +0000199 if 'CC' in os.environ:
Ned Deilycbfb9a52012-06-23 16:02:19 -0700200 cc = os.environ['CC']
Tarek Ziadé36797272010-07-22 12:50:05 +0000201 if 'CXX' in os.environ:
202 cxx = os.environ['CXX']
203 if 'LDSHARED' in os.environ:
204 ldshared = os.environ['LDSHARED']
205 if 'CPP' in os.environ:
206 cpp = os.environ['CPP']
Andrew M. Kuchling29c86232002-11-04 19:53:24 +0000207 else:
Tarek Ziadé36797272010-07-22 12:50:05 +0000208 cpp = cc + " -E" # not always
209 if 'LDFLAGS' in os.environ:
210 ldshared = ldshared + ' ' + os.environ['LDFLAGS']
211 if 'CFLAGS' in os.environ:
212 cflags = opt + ' ' + os.environ['CFLAGS']
213 ldshared = ldshared + ' ' + os.environ['CFLAGS']
214 if 'CPPFLAGS' in os.environ:
215 cpp = cpp + ' ' + os.environ['CPPFLAGS']
216 cflags = cflags + ' ' + os.environ['CPPFLAGS']
217 ldshared = ldshared + ' ' + os.environ['CPPFLAGS']
218 if 'AR' in os.environ:
219 ar = os.environ['AR']
220 if 'ARFLAGS' in os.environ:
221 archiver = ar + ' ' + os.environ['ARFLAGS']
222 else:
223 archiver = ar + ' ' + ar_flags
224
225 cc_cmd = cc + ' ' + cflags
226 compiler.set_executables(
227 preprocessor=cpp,
228 compiler=cc_cmd,
229 compiler_so=cc_cmd + ' ' + ccshared,
230 compiler_cxx=cxx,
231 linker_so=ldshared,
232 linker_exe=cc,
233 archiver=archiver)
234
doko@ubuntu.comd5537d02013-03-21 13:21:49 -0700235 compiler.shared_lib_extension = shlib_suffix
Tarek Ziadé36797272010-07-22 12:50:05 +0000236
237
238def get_config_h_filename():
239 """Return full pathname of installed pyconfig.h file."""
240 if python_build:
241 if os.name == "nt":
Vinay Sajip7ded1f02012-05-26 03:45:29 +0100242 inc_dir = os.path.join(_sys_home or project_base, "PC")
Tarek Ziadé36797272010-07-22 12:50:05 +0000243 else:
Vinay Sajip7ded1f02012-05-26 03:45:29 +0100244 inc_dir = _sys_home or project_base
Tarek Ziadé36797272010-07-22 12:50:05 +0000245 else:
246 inc_dir = get_python_inc(plat_specific=1)
247 if get_python_version() < '2.2':
248 config_h = 'config.h'
249 else:
250 # The name of the config.h file changed in 2.2
251 config_h = 'pyconfig.h'
252 return os.path.join(inc_dir, config_h)
253
Greg Ward1190ee31998-12-18 23:46:33 +0000254
Greg Ward9ddaaa11999-01-06 14:46:06 +0000255def get_makefile_filename():
Tarek Ziadé36797272010-07-22 12:50:05 +0000256 """Return full pathname of installed Makefile from the Python build."""
257 if python_build:
doko@python.org97313302013-01-25 14:33:33 +0100258 return os.path.join(_sys_home or project_base, "Makefile")
Éric Araujofea2d042011-10-08 01:56:52 +0200259 lib_dir = get_python_lib(plat_specific=0, standard_lib=1)
Barry Warsaw14d98ac2010-11-24 19:43:47 +0000260 config_file = 'config-{}{}'.format(get_python_version(), build_flags)
261 return os.path.join(lib_dir, config_file, 'Makefile')
Greg Ward7d73b9e2000-03-09 03:16:05 +0000262
Tarek Ziadé36797272010-07-22 12:50:05 +0000263
264def parse_config_h(fp, g=None):
265 """Parse a config.h-style file.
266
267 A dictionary containing name/value pairs is returned. If an
268 optional dictionary is passed in as the second argument, it is
269 used instead of a new dictionary.
Fred Drake522af3a1999-01-06 16:28:34 +0000270 """
Tarek Ziadé36797272010-07-22 12:50:05 +0000271 if g is None:
272 g = {}
273 define_rx = re.compile("#define ([A-Z][A-Za-z0-9_]+) (.*)\n")
274 undef_rx = re.compile("/[*] #undef ([A-Z][A-Za-z0-9_]+) [*]/\n")
275 #
276 while True:
277 line = fp.readline()
278 if not line:
279 break
280 m = define_rx.match(line)
281 if m:
282 n, v = m.group(1, 2)
283 try: v = int(v)
284 except ValueError: pass
285 g[n] = v
286 else:
287 m = undef_rx.match(line)
288 if m:
289 g[m.group(1)] = 0
290 return g
Greg Ward1190ee31998-12-18 23:46:33 +0000291
Greg Wardd283ce72000-09-17 00:53:02 +0000292
293# Regexes needed for parsing Makefile (and similar syntaxes,
294# like old-style Setup files).
295_variable_rx = re.compile("([a-zA-Z][a-zA-Z0-9_]+)\s*=\s*(.*)")
296_findvar1_rx = re.compile(r"\$\(([A-Za-z][A-Za-z0-9_]*)\)")
297_findvar2_rx = re.compile(r"\${([A-Za-z][A-Za-z0-9_]*)}")
298
Greg Ward3fff8d22000-09-15 00:03:13 +0000299def parse_makefile(fn, g=None):
Tarek Ziadé36797272010-07-22 12:50:05 +0000300 """Parse a Makefile-style file.
Fred Drakec1ee39a2000-03-09 15:54:52 +0000301
302 A dictionary containing name/value pairs is returned. If an
303 optional dictionary is passed in as the second argument, it is
304 used instead of a new dictionary.
Fred Drake522af3a1999-01-06 16:28:34 +0000305 """
Tarek Ziadé36797272010-07-22 12:50:05 +0000306 from distutils.text_file import TextFile
Victor Stinner75d8c5c2010-10-23 17:02:31 +0000307 fp = TextFile(fn, strip_comments=1, skip_blanks=1, join_lines=1, errors="surrogateescape")
Tarek Ziadé36797272010-07-22 12:50:05 +0000308
309 if g is None:
310 g = {}
311 done = {}
312 notdone = {}
313
314 while True:
315 line = fp.readline()
316 if line is None: # eof
317 break
318 m = _variable_rx.match(line)
319 if m:
320 n, v = m.group(1, 2)
321 v = v.strip()
322 # `$$' is a literal `$' in make
323 tmpv = v.replace('$$', '')
324
325 if "$" in tmpv:
326 notdone[n] = v
327 else:
328 try:
329 v = int(v)
330 except ValueError:
331 # insert literal `$'
332 done[n] = v.replace('$$', '$')
333 else:
334 done[n] = v
335
Ronald Oussorene8d252d2010-07-23 09:43:17 +0000336 # Variables with a 'PY_' prefix in the makefile. These need to
337 # be made available without that prefix through sysconfig.
338 # Special care is needed to ensure that variable expansion works, even
339 # if the expansion uses the name without a prefix.
340 renamed_variables = ('CFLAGS', 'LDFLAGS', 'CPPFLAGS')
341
Tarek Ziadé36797272010-07-22 12:50:05 +0000342 # do variable interpolation here
343 while notdone:
344 for name in list(notdone):
345 value = notdone[name]
346 m = _findvar1_rx.search(value) or _findvar2_rx.search(value)
347 if m:
348 n = m.group(1)
349 found = True
350 if n in done:
351 item = str(done[n])
352 elif n in notdone:
353 # get it on a subsequent round
354 found = False
355 elif n in os.environ:
356 # do it like make: fall back to environment
357 item = os.environ[n]
Ronald Oussorene8d252d2010-07-23 09:43:17 +0000358
359 elif n in renamed_variables:
360 if name.startswith('PY_') and name[3:] in renamed_variables:
361 item = ""
362
363 elif 'PY_' + n in notdone:
364 found = False
365
366 else:
367 item = str(done['PY_' + n])
Tarek Ziadé36797272010-07-22 12:50:05 +0000368 else:
369 done[n] = item = ""
370 if found:
371 after = value[m.end():]
372 value = value[:m.start()] + item + after
373 if "$" in after:
374 notdone[name] = value
375 else:
376 try: value = int(value)
377 except ValueError:
378 done[name] = value.strip()
379 else:
380 done[name] = value
381 del notdone[name]
Ronald Oussorene8d252d2010-07-23 09:43:17 +0000382
383 if name.startswith('PY_') \
384 and name[3:] in renamed_variables:
385
386 name = name[3:]
387 if name not in done:
388 done[name] = value
Tarek Ziadé36797272010-07-22 12:50:05 +0000389 else:
390 # bogus variable reference; just drop it since we can't deal
391 del notdone[name]
392
393 fp.close()
394
Antoine Pitroudbec7802010-10-10 09:37:12 +0000395 # strip spurious spaces
396 for k, v in done.items():
397 if isinstance(v, str):
398 done[k] = v.strip()
399
Tarek Ziadé36797272010-07-22 12:50:05 +0000400 # save the results in the global dictionary
401 g.update(done)
402 return g
403
Greg Ward1190ee31998-12-18 23:46:33 +0000404
Greg Wardd283ce72000-09-17 00:53:02 +0000405def expand_makefile_vars(s, vars):
Tarek Ziadé36797272010-07-22 12:50:05 +0000406 """Expand Makefile-style variables -- "${foo}" or "$(foo)" -- in
Greg Wardd283ce72000-09-17 00:53:02 +0000407 'string' according to 'vars' (a dictionary mapping variable names to
408 values). Variables not present in 'vars' are silently expanded to the
409 empty string. The variable values in 'vars' should not contain further
410 variable expansions; if 'vars' is the output of 'parse_makefile()',
411 you're fine. Returns a variable-expanded version of 's'.
412 """
413
414 # This algorithm does multiple expansion, so if vars['foo'] contains
415 # "${bar}", it will expand ${foo} to ${bar}, and then expand
416 # ${bar}... and so forth. This is fine as long as 'vars' comes from
417 # 'parse_makefile()', which takes care of such expansions eagerly,
418 # according to make's variable expansion semantics.
419
Collin Winter5b7e9d72007-08-30 03:52:21 +0000420 while True:
Greg Wardd283ce72000-09-17 00:53:02 +0000421 m = _findvar1_rx.search(s) or _findvar2_rx.search(s)
422 if m:
Greg Wardd283ce72000-09-17 00:53:02 +0000423 (beg, end) = m.span()
424 s = s[0:beg] + vars.get(m.group(1)) + s[end:]
425 else:
426 break
427 return s
Tarek Ziadé36797272010-07-22 12:50:05 +0000428
429
430_config_vars = None
431
432def _init_posix():
433 """Initialize the module as appropriate for POSIX systems."""
434 g = {}
435 # load the installed Makefile:
436 try:
437 filename = get_makefile_filename()
438 parse_makefile(filename, g)
439 except IOError as msg:
440 my_msg = "invalid Python installation: unable to open %s" % filename
441 if hasattr(msg, "strerror"):
442 my_msg = my_msg + " (%s)" % msg.strerror
443
444 raise DistutilsPlatformError(my_msg)
445
446 # load the installed pyconfig.h:
447 try:
448 filename = get_config_h_filename()
Brett Cannon5c035c02010-10-29 22:36:08 +0000449 with open(filename) as file:
450 parse_config_h(file, g)
Tarek Ziadé36797272010-07-22 12:50:05 +0000451 except IOError as msg:
452 my_msg = "invalid Python installation: unable to open %s" % filename
453 if hasattr(msg, "strerror"):
454 my_msg = my_msg + " (%s)" % msg.strerror
455
456 raise DistutilsPlatformError(my_msg)
457
Tarek Ziadé36797272010-07-22 12:50:05 +0000458 # On AIX, there are wrong paths to the linker scripts in the Makefile
459 # -- these paths are relative to the Python source, but when installed
460 # the scripts are in another directory.
461 if python_build:
462 g['LDSHARED'] = g['BLDSHARED']
463
464 elif get_python_version() < '2.1':
465 # The following two branches are for 1.5.2 compatibility.
466 if sys.platform == 'aix4': # what about AIX 3.x ?
467 # Linker script is in the config directory, not in Modules as the
468 # Makefile says.
469 python_lib = get_python_lib(standard_lib=1)
470 ld_so_aix = os.path.join(python_lib, 'config', 'ld_so_aix')
471 python_exp = os.path.join(python_lib, 'config', 'python.exp')
472
473 g['LDSHARED'] = "%s %s -bI:%s" % (ld_so_aix, g['CC'], python_exp)
474
475 global _config_vars
476 _config_vars = g
477
478
479def _init_nt():
480 """Initialize the module as appropriate for NT"""
481 g = {}
482 # set basic install directories
483 g['LIBDEST'] = get_python_lib(plat_specific=0, standard_lib=1)
484 g['BINLIBDEST'] = get_python_lib(plat_specific=1, standard_lib=1)
485
486 # XXX hmmm.. a normal install puts include files here
487 g['INCLUDEPY'] = get_python_inc(plat_specific=0)
488
489 g['SO'] = '.pyd'
doko@ubuntu.comd5537d02013-03-21 13:21:49 -0700490 g['EXT_SUFFIX'] = '.pyd'
Tarek Ziadé36797272010-07-22 12:50:05 +0000491 g['EXE'] = ".exe"
492 g['VERSION'] = get_python_version().replace(".", "")
493 g['BINDIR'] = os.path.dirname(os.path.abspath(sys.executable))
494
495 global _config_vars
496 _config_vars = g
497
498
Tarek Ziadé36797272010-07-22 12:50:05 +0000499def _init_os2():
500 """Initialize the module as appropriate for OS/2"""
501 g = {}
502 # set basic install directories
503 g['LIBDEST'] = get_python_lib(plat_specific=0, standard_lib=1)
504 g['BINLIBDEST'] = get_python_lib(plat_specific=1, standard_lib=1)
505
506 # XXX hmmm.. a normal install puts include files here
507 g['INCLUDEPY'] = get_python_inc(plat_specific=0)
508
509 g['SO'] = '.pyd'
doko@ubuntu.comd5537d02013-03-21 13:21:49 -0700510 g['EXT_SUFFIX'] = '.pyd'
Tarek Ziadé36797272010-07-22 12:50:05 +0000511 g['EXE'] = ".exe"
512
513 global _config_vars
514 _config_vars = g
515
516
517def get_config_vars(*args):
518 """With no arguments, return a dictionary of all configuration
519 variables relevant for the current platform. Generally this includes
520 everything needed to build extensions and install both pure modules and
521 extensions. On Unix, this means every variable defined in Python's
Ned Deilydf8aa2b2012-07-21 05:36:30 -0700522 installed Makefile; on Windows it's a much smaller set.
Tarek Ziadé36797272010-07-22 12:50:05 +0000523
524 With arguments, return a list of values that result from looking up
525 each argument in the configuration variable dictionary.
526 """
527 global _config_vars
528 if _config_vars is None:
529 func = globals().get("_init_" + os.name)
530 if func:
531 func()
532 else:
533 _config_vars = {}
534
535 # Normalized versions of prefix and exec_prefix are handy to have;
536 # in fact, these are the standard versions used most places in the
537 # Distutils.
538 _config_vars['prefix'] = PREFIX
539 _config_vars['exec_prefix'] = EXEC_PREFIX
540
Richard Oudkerk46874ad2012-07-27 12:06:55 +0100541 # Always convert srcdir to an absolute path
542 srcdir = _config_vars.get('srcdir', project_base)
543 if os.name == 'posix':
544 if python_build:
545 # If srcdir is a relative path (typically '.' or '..')
546 # then it should be interpreted relative to the directory
547 # containing Makefile.
548 base = os.path.dirname(get_makefile_filename())
549 srcdir = os.path.join(base, srcdir)
550 else:
551 # srcdir is not meaningful since the installation is
552 # spread about the filesystem. We choose the
553 # directory containing the Makefile since we know it
554 # exists.
555 srcdir = os.path.dirname(get_makefile_filename())
556 _config_vars['srcdir'] = os.path.abspath(os.path.normpath(srcdir))
557
Tarek Ziadé36797272010-07-22 12:50:05 +0000558 # Convert srcdir into an absolute path if it appears necessary.
559 # Normally it is relative to the build directory. However, during
560 # testing, for example, we might be running a non-installed python
561 # from a different directory.
562 if python_build and os.name == "posix":
doko@python.org97313302013-01-25 14:33:33 +0100563 base = project_base
Tarek Ziadé36797272010-07-22 12:50:05 +0000564 if (not os.path.isabs(_config_vars['srcdir']) and
565 base != os.getcwd()):
566 # srcdir is relative and we are not in the same directory
567 # as the executable. Assume executable is in the build
568 # directory and make srcdir absolute.
569 srcdir = os.path.join(base, _config_vars['srcdir'])
570 _config_vars['srcdir'] = os.path.normpath(srcdir)
571
Ned Deilydf8aa2b2012-07-21 05:36:30 -0700572 # OS X platforms require special customization to handle
573 # multi-architecture, multi-os-version installers
Tarek Ziadé36797272010-07-22 12:50:05 +0000574 if sys.platform == 'darwin':
Ned Deilydf8aa2b2012-07-21 05:36:30 -0700575 import _osx_support
576 _osx_support.customize_config_vars(_config_vars)
Ned Deily27471772012-07-15 21:30:03 -0700577
Tarek Ziadé36797272010-07-22 12:50:05 +0000578 if args:
579 vals = []
580 for name in args:
581 vals.append(_config_vars.get(name))
582 return vals
583 else:
584 return _config_vars
585
586def get_config_var(name):
587 """Return the value of a single variable using the dictionary
588 returned by 'get_config_vars()'. Equivalent to
589 get_config_vars().get(name)
590 """
591 return get_config_vars().get(name)