blob: 535ac54b3c02cfd24e51febaf353316aee2b6b05 [file] [log] [blame]
Tarek Ziadé18755702010-02-02 23:17:47 +00001:mod:`sysconfig` --- Provide access to Python's configuration information
2=========================================================================
3
4.. module:: sysconfig
5 :synopsis: Python's configuration information
Éric Araujo19f9b712011-08-19 00:49:18 +02006.. moduleauthor:: Tarek Ziadé <tarek@ziade.org>
7.. sectionauthor:: Tarek Ziadé <tarek@ziade.org>
8
Tarek Ziadé18755702010-02-02 23:17:47 +00009.. index::
10 single: configuration information
11
Raymond Hettingera1993682011-01-27 01:20:32 +000012.. versionadded:: 3.2
13
Éric Araujo19f9b712011-08-19 00:49:18 +020014**Source code:** :source:`Lib/sysconfig.py`
15
Raymond Hettingera1993682011-01-27 01:20:32 +000016--------------
17
Tarek Ziadé18755702010-02-02 23:17:47 +000018The :mod:`sysconfig` module provides access to Python's configuration
Tarek Ziadé667882f2010-02-11 20:47:18 +000019information like the list of installation paths and the configuration variables
20relevant for the current platform.
Tarek Ziadé18755702010-02-02 23:17:47 +000021
22Configuration variables
23-----------------------
24
Benjamin Petersond7c3ed52010-06-27 22:32:30 +000025A Python distribution contains a :file:`Makefile` and a :file:`pyconfig.h`
26header file that are necessary to build both the Python binary itself and
27third-party C extensions compiled using :mod:`distutils`.
Tarek Ziadé18755702010-02-02 23:17:47 +000028
Tarek Ziadé667882f2010-02-11 20:47:18 +000029:mod:`sysconfig` puts all variables found in these files in a dictionary that
30can be accessed using :func:`get_config_vars` or :func:`get_config_var`.
Tarek Ziadé18755702010-02-02 23:17:47 +000031
32Notice that on Windows, it's a much smaller set.
33
34.. function:: get_config_vars(\*args)
35
Tarek Ziadé667882f2010-02-11 20:47:18 +000036 With no arguments, return a dictionary of all configuration variables
37 relevant for the current platform.
Tarek Ziadé18755702010-02-02 23:17:47 +000038
Tarek Ziadé667882f2010-02-11 20:47:18 +000039 With arguments, return a list of values that result from looking up each
40 argument in the configuration variable dictionary.
Tarek Ziadé18755702010-02-02 23:17:47 +000041
Tarek Ziadé667882f2010-02-11 20:47:18 +000042 For each argument, if the value is not found, return ``None``.
43
Tarek Ziadé18755702010-02-02 23:17:47 +000044
45.. function:: get_config_var(name)
46
47 Return the value of a single variable *name*. Equivalent to
Tarek Ziadé667882f2010-02-11 20:47:18 +000048 ``get_config_vars().get(name)``.
Tarek Ziadé18755702010-02-02 23:17:47 +000049
Tarek Ziadé667882f2010-02-11 20:47:18 +000050 If *name* is not found, return ``None``.
Tarek Ziadé18755702010-02-02 23:17:47 +000051
52Example of usage::
53
Tarek Ziadé667882f2010-02-11 20:47:18 +000054 >>> import sysconfig
55 >>> sysconfig.get_config_var('Py_ENABLE_SHARED')
56 0
57 >>> sysconfig.get_config_var('LIBDIR')
58 '/usr/local/lib'
59 >>> sysconfig.get_config_vars('AR', 'CXX')
60 ['ar', 'g++']
Tarek Ziadé18755702010-02-02 23:17:47 +000061
62
63Installation paths
64------------------
65
Tarek Ziadé667882f2010-02-11 20:47:18 +000066Python uses an installation scheme that differs depending on the platform and on
67the installation options. These schemes are stored in :mod:`sysconfig` under
68unique identifiers based on the value returned by :const:`os.name`.
Tarek Ziadé18755702010-02-02 23:17:47 +000069
70Every new component that is installed using :mod:`distutils` or a
Tarek Ziadé667882f2010-02-11 20:47:18 +000071Distutils-based system will follow the same scheme to copy its file in the right
72places.
Tarek Ziadé18755702010-02-02 23:17:47 +000073
74Python currently supports seven schemes:
75
Tarek Ziadé667882f2010-02-11 20:47:18 +000076- *posix_prefix*: scheme for Posix platforms like Linux or Mac OS X. This is
77 the default scheme used when Python or a component is installed.
78- *posix_home*: scheme for Posix platforms used when a *home* option is used
79 upon installation. This scheme is used when a component is installed through
Tarek Ziadé18755702010-02-02 23:17:47 +000080 Distutils with a specific home prefix.
Tarek Ziadé667882f2010-02-11 20:47:18 +000081- *posix_user*: scheme for Posix platforms used when a component is installed
82 through Distutils and the *user* option is used. This scheme defines paths
Tarek Ziadé18755702010-02-02 23:17:47 +000083 located under the user home directory.
Tarek Ziadé667882f2010-02-11 20:47:18 +000084- *nt*: scheme for NT platforms like Windows.
85- *nt_user*: scheme for NT platforms, when the *user* option is used.
Tarek Ziadé18755702010-02-02 23:17:47 +000086
87Each scheme is itself composed of a series of paths and each path has a unique
Tarek Ziadé667882f2010-02-11 20:47:18 +000088identifier. Python currently uses eight paths:
Tarek Ziadé18755702010-02-02 23:17:47 +000089
Tarek Ziadé667882f2010-02-11 20:47:18 +000090- *stdlib*: directory containing the standard Python library files that are not
91 platform-specific.
92- *platstdlib*: directory containing the standard Python library files that are
93 platform-specific.
94- *platlib*: directory for site-specific, platform-specific files.
95- *purelib*: directory for site-specific, non-platform-specific files.
96- *include*: directory for non-platform-specific header files.
97- *platinclude*: directory for platform-specific header files.
98- *scripts*: directory for script files.
99- *data*: directory for data files.
Tarek Ziadé18755702010-02-02 23:17:47 +0000100
Tarek Ziadé667882f2010-02-11 20:47:18 +0000101:mod:`sysconfig` provides some functions to determine these paths.
Tarek Ziadé18755702010-02-02 23:17:47 +0000102
103.. function:: get_scheme_names()
104
105 Return a tuple containing all schemes currently supported in
106 :mod:`sysconfig`.
107
Tarek Ziadé667882f2010-02-11 20:47:18 +0000108
Tarek Ziadé18755702010-02-02 23:17:47 +0000109.. function:: get_path_names()
110
111 Return a tuple containing all path names currently supported in
112 :mod:`sysconfig`.
113
114
115.. function:: get_path(name, [scheme, [vars, [expand]]])
116
117 Return an installation path corresponding to the path *name*, from the
118 install scheme named *scheme*.
119
120 *name* has to be a value from the list returned by :func:`get_path_names`.
121
Tarek Ziadé667882f2010-02-11 20:47:18 +0000122 :mod:`sysconfig` stores installation paths corresponding to each path name,
123 for each platform, with variables to be expanded. For instance the *stdlib*
124 path for the *nt* scheme is: ``{base}/Lib``.
Tarek Ziadé18755702010-02-02 23:17:47 +0000125
126 :func:`get_path` will use the variables returned by :func:`get_config_vars`
Tarek Ziadé667882f2010-02-11 20:47:18 +0000127 to expand the path. All variables have default values for each platform so
128 one may call this function and get the default value.
Tarek Ziadé18755702010-02-02 23:17:47 +0000129
130 If *scheme* is provided, it must be a value from the list returned by
Éric Araujo2bddc532011-11-29 16:34:58 +0100131 :func:`get_scheme_names`. Otherwise, the default scheme for the current
Tarek Ziadé18755702010-02-02 23:17:47 +0000132 platform is used.
133
Tarek Ziadé667882f2010-02-11 20:47:18 +0000134 If *vars* is provided, it must be a dictionary of variables that will update
135 the dictionary return by :func:`get_config_vars`.
Tarek Ziadé18755702010-02-02 23:17:47 +0000136
Tarek Ziadé667882f2010-02-11 20:47:18 +0000137 If *expand* is set to ``False``, the path will not be expanded using the
138 variables.
Tarek Ziadé18755702010-02-02 23:17:47 +0000139
Tarek Ziadé667882f2010-02-11 20:47:18 +0000140 If *name* is not found, return ``None``.
Tarek Ziadé18755702010-02-02 23:17:47 +0000141
142
143.. function:: get_paths([scheme, [vars, [expand]]])
144
Tarek Ziadé667882f2010-02-11 20:47:18 +0000145 Return a dictionary containing all installation paths corresponding to an
Tarek Ziadé18755702010-02-02 23:17:47 +0000146 installation scheme. See :func:`get_path` for more information.
147
148 If *scheme* is not provided, will use the default scheme for the current
149 platform.
150
Tarek Ziadé667882f2010-02-11 20:47:18 +0000151 If *vars* is provided, it must be a dictionary of variables that will
152 update the dictionary used to expand the paths.
Tarek Ziadé18755702010-02-02 23:17:47 +0000153
154 If *expand* is set to False, the paths will not be expanded.
155
156 If *scheme* is not an existing scheme, :func:`get_paths` will raise a
157 :exc:`KeyError`.
158
159
160Other functions
161---------------
162
163.. function:: get_python_version()
164
Tarek Ziadé667882f2010-02-11 20:47:18 +0000165 Return the ``MAJOR.MINOR`` Python version number as a string. Similar to
Tarek Ziadé18755702010-02-02 23:17:47 +0000166 ``sys.version[:3]``.
167
Tarek Ziadé667882f2010-02-11 20:47:18 +0000168
Tarek Ziadé18755702010-02-02 23:17:47 +0000169.. function:: get_platform()
170
171 Return a string that identifies the current platform.
172
173 This is used mainly to distinguish platform-specific build directories and
Tarek Ziadé667882f2010-02-11 20:47:18 +0000174 platform-specific built distributions. Typically includes the OS name and
175 version and the architecture (as supplied by :func:`os.uname`), although the
176 exact information included depends on the OS; e.g. for IRIX the architecture
177 isn't particularly important (IRIX only runs on SGI hardware), but for Linux
178 the kernel version isn't particularly important.
Tarek Ziadé18755702010-02-02 23:17:47 +0000179
180 Examples of returned values:
181
182 - linux-i586
183 - linux-alpha (?)
184 - solaris-2.6-sun4u
185 - irix-5.3
186 - irix64-6.2
187
188 Windows will return one of:
189
190 - win-amd64 (64bit Windows on AMD64 (aka x86_64, Intel64, EM64T, etc)
191 - win-ia64 (64bit Windows on Itanium)
192 - win32 (all others - specifically, sys.platform is returned)
193
Tarek Ziadé667882f2010-02-11 20:47:18 +0000194 Mac OS X can return:
Tarek Ziadé18755702010-02-02 23:17:47 +0000195
196 - macosx-10.6-ppc
197 - macosx-10.4-ppc64
198 - macosx-10.3-i386
199 - macosx-10.4-fat
200
Tarek Ziadé667882f2010-02-11 20:47:18 +0000201 For other non-POSIX platforms, currently just returns :data:`sys.platform`.
Tarek Ziadé18755702010-02-02 23:17:47 +0000202
203
Tarek Ziadé667882f2010-02-11 20:47:18 +0000204.. function:: is_python_build()
Tarek Ziadé18755702010-02-02 23:17:47 +0000205
Tarek Ziadé667882f2010-02-11 20:47:18 +0000206 Return ``True`` if the current Python installation was built from source.
Tarek Ziadé18755702010-02-02 23:17:47 +0000207
208
Tarek Ziadé667882f2010-02-11 20:47:18 +0000209.. function:: parse_config_h(fp[, vars])
Tarek Ziadé18755702010-02-02 23:17:47 +0000210
Tarek Ziadé667882f2010-02-11 20:47:18 +0000211 Parse a :file:`config.h`\-style file.
Tarek Ziadé18755702010-02-02 23:17:47 +0000212
Tarek Ziadé667882f2010-02-11 20:47:18 +0000213 *fp* is a file-like object pointing to the :file:`config.h`\-like file.
Tarek Ziadé18755702010-02-02 23:17:47 +0000214
215 A dictionary containing name/value pairs is returned. If an optional
Tarek Ziadé667882f2010-02-11 20:47:18 +0000216 dictionary is passed in as the second argument, it is used instead of a new
217 dictionary, and updated with the values read in the file.
Tarek Ziadé18755702010-02-02 23:17:47 +0000218
219
Tarek Ziadé667882f2010-02-11 20:47:18 +0000220.. function:: get_config_h_filename()
Tarek Ziadé18755702010-02-02 23:17:47 +0000221
Tarek Ziadé667882f2010-02-11 20:47:18 +0000222 Return the path of :file:`pyconfig.h`.
Tarek Ziadéa7514992010-05-25 09:44:36 +0000223
Barry Warsawebbef6f2010-09-20 15:29:53 +0000224.. function:: get_makefile_filename()
225
226 Return the path of :file:`Makefile`.
227
Tarek Ziadéa7514992010-05-25 09:44:36 +0000228Using :mod:`sysconfig` as a script
229----------------------------------
230
231You can use :mod:`sysconfig` as a script with Python's *-m* option::
232
233 $ python -m sysconfig
234 Platform: "macosx-10.4-i386"
235 Python version: "3.2"
236 Current installation scheme: "posix_prefix"
237
238 Paths:
239 data = "/usr/local"
240 include = "/Users/tarek/Dev/svn.python.org/py3k/Include"
241 platinclude = "."
242 platlib = "/usr/local/lib/python3.2/site-packages"
243 platstdlib = "/usr/local/lib/python3.2"
244 purelib = "/usr/local/lib/python3.2/site-packages"
245 scripts = "/usr/local/bin"
246 stdlib = "/usr/local/lib/python3.2"
247
248 Variables:
249 AC_APPLE_UNIVERSAL_BUILD = "0"
250 AIX_GENUINE_CPLUSPLUS = "0"
251 AR = "ar"
252 ARFLAGS = "rc"
253 ASDLGEN = "./Parser/asdl_c.py"
254 ...
255
256This call will print in the standard output the information returned by
257:func:`get_platform`, :func:`get_python_version`, :func:`get_path` and
258:func:`get_config_vars`.