blob: 9f549fbc51304508c89309515d4e886e8457e943 [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
Terry Jan Reedyfa089b92016-06-11 15:02:54 -04006
Éric Araujo19f9b712011-08-19 00:49:18 +02007.. moduleauthor:: Tarek Ziadé <tarek@ziade.org>
8.. sectionauthor:: Tarek Ziadé <tarek@ziade.org>
9
Raymond Hettingera1993682011-01-27 01:20:32 +000010.. versionadded:: 3.2
11
Éric Araujo19f9b712011-08-19 00:49:18 +020012**Source code:** :source:`Lib/sysconfig.py`
13
Terry Jan Reedyfa089b92016-06-11 15:02:54 -040014.. index::
15 single: configuration information
16
Raymond Hettingera1993682011-01-27 01:20:32 +000017--------------
18
Tarek Ziadé18755702010-02-02 23:17:47 +000019The :mod:`sysconfig` module provides access to Python's configuration
Tarek Ziadé667882f2010-02-11 20:47:18 +000020information like the list of installation paths and the configuration variables
21relevant for the current platform.
Tarek Ziadé18755702010-02-02 23:17:47 +000022
23Configuration variables
24-----------------------
25
Benjamin Petersond7c3ed52010-06-27 22:32:30 +000026A Python distribution contains a :file:`Makefile` and a :file:`pyconfig.h`
27header file that are necessary to build both the Python binary itself and
28third-party C extensions compiled using :mod:`distutils`.
Tarek Ziadé18755702010-02-02 23:17:47 +000029
Tarek Ziadé667882f2010-02-11 20:47:18 +000030:mod:`sysconfig` puts all variables found in these files in a dictionary that
31can be accessed using :func:`get_config_vars` or :func:`get_config_var`.
Tarek Ziadé18755702010-02-02 23:17:47 +000032
33Notice that on Windows, it's a much smaller set.
34
35.. function:: get_config_vars(\*args)
36
Tarek Ziadé667882f2010-02-11 20:47:18 +000037 With no arguments, return a dictionary of all configuration variables
38 relevant for the current platform.
Tarek Ziadé18755702010-02-02 23:17:47 +000039
Tarek Ziadé667882f2010-02-11 20:47:18 +000040 With arguments, return a list of values that result from looking up each
41 argument in the configuration variable dictionary.
Tarek Ziadé18755702010-02-02 23:17:47 +000042
Tarek Ziadé667882f2010-02-11 20:47:18 +000043 For each argument, if the value is not found, return ``None``.
44
Tarek Ziadé18755702010-02-02 23:17:47 +000045
46.. function:: get_config_var(name)
47
48 Return the value of a single variable *name*. Equivalent to
Tarek Ziadé667882f2010-02-11 20:47:18 +000049 ``get_config_vars().get(name)``.
Tarek Ziadé18755702010-02-02 23:17:47 +000050
Tarek Ziadé667882f2010-02-11 20:47:18 +000051 If *name* is not found, return ``None``.
Tarek Ziadé18755702010-02-02 23:17:47 +000052
53Example of usage::
54
Tarek Ziadé667882f2010-02-11 20:47:18 +000055 >>> import sysconfig
56 >>> sysconfig.get_config_var('Py_ENABLE_SHARED')
57 0
58 >>> sysconfig.get_config_var('LIBDIR')
59 '/usr/local/lib'
60 >>> sysconfig.get_config_vars('AR', 'CXX')
61 ['ar', 'g++']
Tarek Ziadé18755702010-02-02 23:17:47 +000062
63
64Installation paths
65------------------
66
Tarek Ziadé667882f2010-02-11 20:47:18 +000067Python uses an installation scheme that differs depending on the platform and on
68the installation options. These schemes are stored in :mod:`sysconfig` under
69unique identifiers based on the value returned by :const:`os.name`.
Tarek Ziadé18755702010-02-02 23:17:47 +000070
71Every new component that is installed using :mod:`distutils` or a
Tarek Ziadé667882f2010-02-11 20:47:18 +000072Distutils-based system will follow the same scheme to copy its file in the right
73places.
Tarek Ziadé18755702010-02-02 23:17:47 +000074
75Python currently supports seven schemes:
76
Tarek Ziadé667882f2010-02-11 20:47:18 +000077- *posix_prefix*: scheme for Posix platforms like Linux or Mac OS X. This is
78 the default scheme used when Python or a component is installed.
79- *posix_home*: scheme for Posix platforms used when a *home* option is used
80 upon installation. This scheme is used when a component is installed through
Tarek Ziadé18755702010-02-02 23:17:47 +000081 Distutils with a specific home prefix.
Tarek Ziadé667882f2010-02-11 20:47:18 +000082- *posix_user*: scheme for Posix platforms used when a component is installed
83 through Distutils and the *user* option is used. This scheme defines paths
Tarek Ziadé18755702010-02-02 23:17:47 +000084 located under the user home directory.
Tarek Ziadé667882f2010-02-11 20:47:18 +000085- *nt*: scheme for NT platforms like Windows.
86- *nt_user*: scheme for NT platforms, when the *user* option is used.
Tarek Ziadé18755702010-02-02 23:17:47 +000087
88Each scheme is itself composed of a series of paths and each path has a unique
Tarek Ziadé667882f2010-02-11 20:47:18 +000089identifier. Python currently uses eight paths:
Tarek Ziadé18755702010-02-02 23:17:47 +000090
Tarek Ziadé667882f2010-02-11 20:47:18 +000091- *stdlib*: directory containing the standard Python library files that are not
92 platform-specific.
93- *platstdlib*: directory containing the standard Python library files that are
94 platform-specific.
95- *platlib*: directory for site-specific, platform-specific files.
96- *purelib*: directory for site-specific, non-platform-specific files.
97- *include*: directory for non-platform-specific header files.
98- *platinclude*: directory for platform-specific header files.
99- *scripts*: directory for script files.
100- *data*: directory for data files.
Tarek Ziadé18755702010-02-02 23:17:47 +0000101
Tarek Ziadé667882f2010-02-11 20:47:18 +0000102:mod:`sysconfig` provides some functions to determine these paths.
Tarek Ziadé18755702010-02-02 23:17:47 +0000103
104.. function:: get_scheme_names()
105
106 Return a tuple containing all schemes currently supported in
107 :mod:`sysconfig`.
108
Tarek Ziadé667882f2010-02-11 20:47:18 +0000109
Tarek Ziadé18755702010-02-02 23:17:47 +0000110.. function:: get_path_names()
111
112 Return a tuple containing all path names currently supported in
113 :mod:`sysconfig`.
114
115
116.. function:: get_path(name, [scheme, [vars, [expand]]])
117
118 Return an installation path corresponding to the path *name*, from the
119 install scheme named *scheme*.
120
121 *name* has to be a value from the list returned by :func:`get_path_names`.
122
Tarek Ziadé667882f2010-02-11 20:47:18 +0000123 :mod:`sysconfig` stores installation paths corresponding to each path name,
124 for each platform, with variables to be expanded. For instance the *stdlib*
125 path for the *nt* scheme is: ``{base}/Lib``.
Tarek Ziadé18755702010-02-02 23:17:47 +0000126
127 :func:`get_path` will use the variables returned by :func:`get_config_vars`
Tarek Ziadé667882f2010-02-11 20:47:18 +0000128 to expand the path. All variables have default values for each platform so
129 one may call this function and get the default value.
Tarek Ziadé18755702010-02-02 23:17:47 +0000130
131 If *scheme* is provided, it must be a value from the list returned by
Éric Araujo2bddc532011-11-29 16:34:58 +0100132 :func:`get_scheme_names`. Otherwise, the default scheme for the current
Tarek Ziadé18755702010-02-02 23:17:47 +0000133 platform is used.
134
Tarek Ziadé667882f2010-02-11 20:47:18 +0000135 If *vars* is provided, it must be a dictionary of variables that will update
136 the dictionary return by :func:`get_config_vars`.
Tarek Ziadé18755702010-02-02 23:17:47 +0000137
Tarek Ziadé667882f2010-02-11 20:47:18 +0000138 If *expand* is set to ``False``, the path will not be expanded using the
139 variables.
Tarek Ziadé18755702010-02-02 23:17:47 +0000140
Tarek Ziadé667882f2010-02-11 20:47:18 +0000141 If *name* is not found, return ``None``.
Tarek Ziadé18755702010-02-02 23:17:47 +0000142
143
144.. function:: get_paths([scheme, [vars, [expand]]])
145
Tarek Ziadé667882f2010-02-11 20:47:18 +0000146 Return a dictionary containing all installation paths corresponding to an
Tarek Ziadé18755702010-02-02 23:17:47 +0000147 installation scheme. See :func:`get_path` for more information.
148
149 If *scheme* is not provided, will use the default scheme for the current
150 platform.
151
Tarek Ziadé667882f2010-02-11 20:47:18 +0000152 If *vars* is provided, it must be a dictionary of variables that will
153 update the dictionary used to expand the paths.
Tarek Ziadé18755702010-02-02 23:17:47 +0000154
Serhiy Storchaka4adf01c2016-10-19 18:30:05 +0300155 If *expand* is set to false, the paths will not be expanded.
Tarek Ziadé18755702010-02-02 23:17:47 +0000156
157 If *scheme* is not an existing scheme, :func:`get_paths` will raise a
158 :exc:`KeyError`.
159
160
161Other functions
162---------------
163
164.. function:: get_python_version()
165
Tarek Ziadé667882f2010-02-11 20:47:18 +0000166 Return the ``MAJOR.MINOR`` Python version number as a string. Similar to
Serhiy Storchaka885bdc42016-02-11 13:10:36 +0200167 ``'%d.%d' % sys.version_info[:2]``.
Tarek Ziadé18755702010-02-02 23:17:47 +0000168
Tarek Ziadé667882f2010-02-11 20:47:18 +0000169
Tarek Ziadé18755702010-02-02 23:17:47 +0000170.. function:: get_platform()
171
172 Return a string that identifies the current platform.
173
174 This is used mainly to distinguish platform-specific build directories and
Tarek Ziadé667882f2010-02-11 20:47:18 +0000175 platform-specific built distributions. Typically includes the OS name and
Benjamin Peterson06930632017-09-04 16:36:05 -0700176 version and the architecture (as supplied by 'os.uname()'), although the
177 exact information included depends on the OS; e.g., on Linux, the kernel
178 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
Tarek Ziadé18755702010-02-02 23:17:47 +0000185
186 Windows will return one of:
187
188 - win-amd64 (64bit Windows on AMD64 (aka x86_64, Intel64, EM64T, etc)
Tarek Ziadé18755702010-02-02 23:17:47 +0000189 - win32 (all others - specifically, sys.platform is returned)
190
Tarek Ziadé667882f2010-02-11 20:47:18 +0000191 Mac OS X can return:
Tarek Ziadé18755702010-02-02 23:17:47 +0000192
193 - macosx-10.6-ppc
194 - macosx-10.4-ppc64
195 - macosx-10.3-i386
196 - macosx-10.4-fat
197
Tarek Ziadé667882f2010-02-11 20:47:18 +0000198 For other non-POSIX platforms, currently just returns :data:`sys.platform`.
Tarek Ziadé18755702010-02-02 23:17:47 +0000199
200
Tarek Ziadé667882f2010-02-11 20:47:18 +0000201.. function:: is_python_build()
Tarek Ziadé18755702010-02-02 23:17:47 +0000202
Vinay Sajip37cac762016-08-25 15:13:24 +0100203 Return ``True`` if the running Python interpreter was built from source and
204 is being run from its built location, and not from a location resulting from
205 e.g. running ``make install`` or installing via a binary installer.
Tarek Ziadé18755702010-02-02 23:17:47 +0000206
207
Tarek Ziadé667882f2010-02-11 20:47:18 +0000208.. function:: parse_config_h(fp[, vars])
Tarek Ziadé18755702010-02-02 23:17:47 +0000209
Tarek Ziadé667882f2010-02-11 20:47:18 +0000210 Parse a :file:`config.h`\-style file.
Tarek Ziadé18755702010-02-02 23:17:47 +0000211
Tarek Ziadé667882f2010-02-11 20:47:18 +0000212 *fp* is a file-like object pointing to the :file:`config.h`\-like file.
Tarek Ziadé18755702010-02-02 23:17:47 +0000213
214 A dictionary containing name/value pairs is returned. If an optional
Tarek Ziadé667882f2010-02-11 20:47:18 +0000215 dictionary is passed in as the second argument, it is used instead of a new
216 dictionary, and updated with the values read in the file.
Tarek Ziadé18755702010-02-02 23:17:47 +0000217
218
Tarek Ziadé667882f2010-02-11 20:47:18 +0000219.. function:: get_config_h_filename()
Tarek Ziadé18755702010-02-02 23:17:47 +0000220
Tarek Ziadé667882f2010-02-11 20:47:18 +0000221 Return the path of :file:`pyconfig.h`.
Tarek Ziadéa7514992010-05-25 09:44:36 +0000222
Barry Warsawebbef6f2010-09-20 15:29:53 +0000223.. function:: get_makefile_filename()
224
225 Return the path of :file:`Makefile`.
226
Tarek Ziadéa7514992010-05-25 09:44:36 +0000227Using :mod:`sysconfig` as a script
228----------------------------------
229
Martin Panter1050d2d2016-07-26 11:18:21 +0200230You can use :mod:`sysconfig` as a script with Python's *-m* option:
231
232.. code-block:: shell-session
Tarek Ziadéa7514992010-05-25 09:44:36 +0000233
234 $ python -m sysconfig
235 Platform: "macosx-10.4-i386"
236 Python version: "3.2"
237 Current installation scheme: "posix_prefix"
238
239 Paths:
240 data = "/usr/local"
241 include = "/Users/tarek/Dev/svn.python.org/py3k/Include"
242 platinclude = "."
243 platlib = "/usr/local/lib/python3.2/site-packages"
244 platstdlib = "/usr/local/lib/python3.2"
245 purelib = "/usr/local/lib/python3.2/site-packages"
246 scripts = "/usr/local/bin"
247 stdlib = "/usr/local/lib/python3.2"
248
249 Variables:
250 AC_APPLE_UNIVERSAL_BUILD = "0"
251 AIX_GENUINE_CPLUSPLUS = "0"
252 AR = "ar"
253 ARFLAGS = "rc"
Tarek Ziadéa7514992010-05-25 09:44:36 +0000254 ...
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`.