blob: 773480b62b5dc82d616f2befc2868f789873bc3d [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
6.. moduleauthor:: Tarek Ziade <tarek@ziade.org>
7.. sectionauthor:: Tarek Ziade <tarek@ziade.org>
Ezio Melottif8754a62010-03-21 07:16:43 +00008.. versionadded:: 3.2
Tarek Ziadé18755702010-02-02 23:17:47 +00009.. index::
10 single: configuration information
11
12The :mod:`sysconfig` module provides access to Python's configuration
Tarek Ziadé667882f2010-02-11 20:47:18 +000013information like the list of installation paths and the configuration variables
14relevant for the current platform.
Tarek Ziadé18755702010-02-02 23:17:47 +000015
16Configuration variables
17-----------------------
18
Benjamin Petersond7c3ed52010-06-27 22:32:30 +000019A Python distribution contains a :file:`Makefile` and a :file:`pyconfig.h`
20header file that are necessary to build both the Python binary itself and
21third-party C extensions compiled using :mod:`distutils`.
Tarek Ziadé18755702010-02-02 23:17:47 +000022
Tarek Ziadé667882f2010-02-11 20:47:18 +000023:mod:`sysconfig` puts all variables found in these files in a dictionary that
24can be accessed using :func:`get_config_vars` or :func:`get_config_var`.
Tarek Ziadé18755702010-02-02 23:17:47 +000025
26Notice that on Windows, it's a much smaller set.
27
28.. function:: get_config_vars(\*args)
29
Tarek Ziadé667882f2010-02-11 20:47:18 +000030 With no arguments, return a dictionary of all configuration variables
31 relevant for the current platform.
Tarek Ziadé18755702010-02-02 23:17:47 +000032
Tarek Ziadé667882f2010-02-11 20:47:18 +000033 With arguments, return a list of values that result from looking up each
34 argument in the configuration variable dictionary.
Tarek Ziadé18755702010-02-02 23:17:47 +000035
Tarek Ziadé667882f2010-02-11 20:47:18 +000036 For each argument, if the value is not found, return ``None``.
37
Tarek Ziadé18755702010-02-02 23:17:47 +000038
39.. function:: get_config_var(name)
40
41 Return the value of a single variable *name*. Equivalent to
Tarek Ziadé667882f2010-02-11 20:47:18 +000042 ``get_config_vars().get(name)``.
Tarek Ziadé18755702010-02-02 23:17:47 +000043
Tarek Ziadé667882f2010-02-11 20:47:18 +000044 If *name* is not found, return ``None``.
Tarek Ziadé18755702010-02-02 23:17:47 +000045
46Example of usage::
47
Tarek Ziadé667882f2010-02-11 20:47:18 +000048 >>> import sysconfig
49 >>> sysconfig.get_config_var('Py_ENABLE_SHARED')
50 0
51 >>> sysconfig.get_config_var('LIBDIR')
52 '/usr/local/lib'
53 >>> sysconfig.get_config_vars('AR', 'CXX')
54 ['ar', 'g++']
Tarek Ziadé18755702010-02-02 23:17:47 +000055
56
57Installation paths
58------------------
59
Tarek Ziadé667882f2010-02-11 20:47:18 +000060Python uses an installation scheme that differs depending on the platform and on
61the installation options. These schemes are stored in :mod:`sysconfig` under
62unique identifiers based on the value returned by :const:`os.name`.
Tarek Ziadé18755702010-02-02 23:17:47 +000063
64Every new component that is installed using :mod:`distutils` or a
Tarek Ziadé667882f2010-02-11 20:47:18 +000065Distutils-based system will follow the same scheme to copy its file in the right
66places.
Tarek Ziadé18755702010-02-02 23:17:47 +000067
68Python currently supports seven schemes:
69
Tarek Ziadé667882f2010-02-11 20:47:18 +000070- *posix_prefix*: scheme for Posix platforms like Linux or Mac OS X. This is
71 the default scheme used when Python or a component is installed.
72- *posix_home*: scheme for Posix platforms used when a *home* option is used
73 upon installation. This scheme is used when a component is installed through
Tarek Ziadé18755702010-02-02 23:17:47 +000074 Distutils with a specific home prefix.
Tarek Ziadé667882f2010-02-11 20:47:18 +000075- *posix_user*: scheme for Posix platforms used when a component is installed
76 through Distutils and the *user* option is used. This scheme defines paths
Tarek Ziadé18755702010-02-02 23:17:47 +000077 located under the user home directory.
Tarek Ziadé667882f2010-02-11 20:47:18 +000078- *nt*: scheme for NT platforms like Windows.
79- *nt_user*: scheme for NT platforms, when the *user* option is used.
80- *os2*: scheme for OS/2 platforms.
81- *os2_home*: scheme for OS/2 patforms, when the *user* option is used.
Tarek Ziadé18755702010-02-02 23:17:47 +000082
83Each scheme is itself composed of a series of paths and each path has a unique
Tarek Ziadé667882f2010-02-11 20:47:18 +000084identifier. Python currently uses eight paths:
Tarek Ziadé18755702010-02-02 23:17:47 +000085
Tarek Ziadé667882f2010-02-11 20:47:18 +000086- *stdlib*: directory containing the standard Python library files that are not
87 platform-specific.
88- *platstdlib*: directory containing the standard Python library files that are
89 platform-specific.
90- *platlib*: directory for site-specific, platform-specific files.
91- *purelib*: directory for site-specific, non-platform-specific files.
92- *include*: directory for non-platform-specific header files.
93- *platinclude*: directory for platform-specific header files.
94- *scripts*: directory for script files.
95- *data*: directory for data files.
Tarek Ziadé18755702010-02-02 23:17:47 +000096
Tarek Ziadé667882f2010-02-11 20:47:18 +000097:mod:`sysconfig` provides some functions to determine these paths.
Tarek Ziadé18755702010-02-02 23:17:47 +000098
99.. function:: get_scheme_names()
100
101 Return a tuple containing all schemes currently supported in
102 :mod:`sysconfig`.
103
Tarek Ziadé667882f2010-02-11 20:47:18 +0000104
Tarek Ziadé18755702010-02-02 23:17:47 +0000105.. function:: get_path_names()
106
107 Return a tuple containing all path names currently supported in
108 :mod:`sysconfig`.
109
110
111.. function:: get_path(name, [scheme, [vars, [expand]]])
112
113 Return an installation path corresponding to the path *name*, from the
114 install scheme named *scheme*.
115
116 *name* has to be a value from the list returned by :func:`get_path_names`.
117
Tarek Ziadé667882f2010-02-11 20:47:18 +0000118 :mod:`sysconfig` stores installation paths corresponding to each path name,
119 for each platform, with variables to be expanded. For instance the *stdlib*
120 path for the *nt* scheme is: ``{base}/Lib``.
Tarek Ziadé18755702010-02-02 23:17:47 +0000121
122 :func:`get_path` will use the variables returned by :func:`get_config_vars`
Tarek Ziadé667882f2010-02-11 20:47:18 +0000123 to expand the path. All variables have default values for each platform so
124 one may call this function and get the default value.
Tarek Ziadé18755702010-02-02 23:17:47 +0000125
126 If *scheme* is provided, it must be a value from the list returned by
Tarek Ziadé667882f2010-02-11 20:47:18 +0000127 :func:`get_path_names`. Otherwise, the default scheme for the current
Tarek Ziadé18755702010-02-02 23:17:47 +0000128 platform is used.
129
Tarek Ziadé667882f2010-02-11 20:47:18 +0000130 If *vars* is provided, it must be a dictionary of variables that will update
131 the dictionary return by :func:`get_config_vars`.
Tarek Ziadé18755702010-02-02 23:17:47 +0000132
Tarek Ziadé667882f2010-02-11 20:47:18 +0000133 If *expand* is set to ``False``, the path will not be expanded using the
134 variables.
Tarek Ziadé18755702010-02-02 23:17:47 +0000135
Tarek Ziadé667882f2010-02-11 20:47:18 +0000136 If *name* is not found, return ``None``.
Tarek Ziadé18755702010-02-02 23:17:47 +0000137
138
139.. function:: get_paths([scheme, [vars, [expand]]])
140
Tarek Ziadé667882f2010-02-11 20:47:18 +0000141 Return a dictionary containing all installation paths corresponding to an
Tarek Ziadé18755702010-02-02 23:17:47 +0000142 installation scheme. See :func:`get_path` for more information.
143
144 If *scheme* is not provided, will use the default scheme for the current
145 platform.
146
Tarek Ziadé667882f2010-02-11 20:47:18 +0000147 If *vars* is provided, it must be a dictionary of variables that will
148 update the dictionary used to expand the paths.
Tarek Ziadé18755702010-02-02 23:17:47 +0000149
150 If *expand* is set to False, the paths will not be expanded.
151
152 If *scheme* is not an existing scheme, :func:`get_paths` will raise a
153 :exc:`KeyError`.
154
155
156Other functions
157---------------
158
159.. function:: get_python_version()
160
Tarek Ziadé667882f2010-02-11 20:47:18 +0000161 Return the ``MAJOR.MINOR`` Python version number as a string. Similar to
Tarek Ziadé18755702010-02-02 23:17:47 +0000162 ``sys.version[:3]``.
163
Tarek Ziadé667882f2010-02-11 20:47:18 +0000164
Tarek Ziadé18755702010-02-02 23:17:47 +0000165.. function:: get_platform()
166
167 Return a string that identifies the current platform.
168
169 This is used mainly to distinguish platform-specific build directories and
Tarek Ziadé667882f2010-02-11 20:47:18 +0000170 platform-specific built distributions. Typically includes the OS name and
171 version and the architecture (as supplied by :func:`os.uname`), although the
172 exact information included depends on the OS; e.g. for IRIX the architecture
173 isn't particularly important (IRIX only runs on SGI hardware), but for Linux
174 the kernel version isn't particularly important.
Tarek Ziadé18755702010-02-02 23:17:47 +0000175
176 Examples of returned values:
177
178 - linux-i586
179 - linux-alpha (?)
180 - solaris-2.6-sun4u
181 - irix-5.3
182 - irix64-6.2
183
184 Windows will return one of:
185
186 - win-amd64 (64bit Windows on AMD64 (aka x86_64, Intel64, EM64T, etc)
187 - win-ia64 (64bit Windows on Itanium)
188 - win32 (all others - specifically, sys.platform is returned)
189
Tarek Ziadé667882f2010-02-11 20:47:18 +0000190 Mac OS X can return:
Tarek Ziadé18755702010-02-02 23:17:47 +0000191
192 - macosx-10.6-ppc
193 - macosx-10.4-ppc64
194 - macosx-10.3-i386
195 - macosx-10.4-fat
196
Tarek Ziadé667882f2010-02-11 20:47:18 +0000197 For other non-POSIX platforms, currently just returns :data:`sys.platform`.
Tarek Ziadé18755702010-02-02 23:17:47 +0000198
199
Tarek Ziadé667882f2010-02-11 20:47:18 +0000200.. function:: is_python_build()
Tarek Ziadé18755702010-02-02 23:17:47 +0000201
Tarek Ziadé667882f2010-02-11 20:47:18 +0000202 Return ``True`` if the current Python installation was built from source.
Tarek Ziadé18755702010-02-02 23:17:47 +0000203
204
Tarek Ziadé667882f2010-02-11 20:47:18 +0000205.. function:: parse_config_h(fp[, vars])
Tarek Ziadé18755702010-02-02 23:17:47 +0000206
Tarek Ziadé667882f2010-02-11 20:47:18 +0000207 Parse a :file:`config.h`\-style file.
Tarek Ziadé18755702010-02-02 23:17:47 +0000208
Tarek Ziadé667882f2010-02-11 20:47:18 +0000209 *fp* is a file-like object pointing to the :file:`config.h`\-like file.
Tarek Ziadé18755702010-02-02 23:17:47 +0000210
211 A dictionary containing name/value pairs is returned. If an optional
Tarek Ziadé667882f2010-02-11 20:47:18 +0000212 dictionary is passed in as the second argument, it is used instead of a new
213 dictionary, and updated with the values read in the file.
Tarek Ziadé18755702010-02-02 23:17:47 +0000214
215
Tarek Ziadé667882f2010-02-11 20:47:18 +0000216.. function:: get_config_h_filename()
Tarek Ziadé18755702010-02-02 23:17:47 +0000217
Tarek Ziadé667882f2010-02-11 20:47:18 +0000218 Return the path of :file:`pyconfig.h`.
Tarek Ziadéa7514992010-05-25 09:44:36 +0000219
Barry Warsawebbef6f2010-09-20 15:29:53 +0000220.. function:: get_makefile_filename()
221
222 Return the path of :file:`Makefile`.
223
Tarek Ziadéa7514992010-05-25 09:44:36 +0000224Using :mod:`sysconfig` as a script
225----------------------------------
226
227You can use :mod:`sysconfig` as a script with Python's *-m* option::
228
229 $ python -m sysconfig
230 Platform: "macosx-10.4-i386"
231 Python version: "3.2"
232 Current installation scheme: "posix_prefix"
233
234 Paths:
235 data = "/usr/local"
236 include = "/Users/tarek/Dev/svn.python.org/py3k/Include"
237 platinclude = "."
238 platlib = "/usr/local/lib/python3.2/site-packages"
239 platstdlib = "/usr/local/lib/python3.2"
240 purelib = "/usr/local/lib/python3.2/site-packages"
241 scripts = "/usr/local/bin"
242 stdlib = "/usr/local/lib/python3.2"
243
244 Variables:
245 AC_APPLE_UNIVERSAL_BUILD = "0"
246 AIX_GENUINE_CPLUSPLUS = "0"
247 AR = "ar"
248 ARFLAGS = "rc"
249 ASDLGEN = "./Parser/asdl_c.py"
250 ...
251
252This call will print in the standard output the information returned by
253:func:`get_platform`, :func:`get_python_version`, :func:`get_path` and
254:func:`get_config_vars`.