| Tarek Ziadé | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 1 | :mod:`sysconfig` --- Provide access to Python's configuration information | 
 | 2 | ========================================================================= | 
 | 3 |  | 
 | 4 | .. module:: sysconfig | 
 | 5 |    :synopsis: Python's configuration information | 
| Terry Jan Reedy | fa089b9 | 2016-06-11 15:02:54 -0400 | [diff] [blame] | 6 |  | 
| Éric Araujo | 19f9b71 | 2011-08-19 00:49:18 +0200 | [diff] [blame] | 7 | .. moduleauthor:: Tarek Ziadé <tarek@ziade.org> | 
 | 8 | .. sectionauthor:: Tarek Ziadé <tarek@ziade.org> | 
 | 9 |  | 
| Raymond Hettinger | a199368 | 2011-01-27 01:20:32 +0000 | [diff] [blame] | 10 | .. versionadded:: 3.2 | 
 | 11 |  | 
| Éric Araujo | 19f9b71 | 2011-08-19 00:49:18 +0200 | [diff] [blame] | 12 | **Source code:** :source:`Lib/sysconfig.py` | 
 | 13 |  | 
| Terry Jan Reedy | fa089b9 | 2016-06-11 15:02:54 -0400 | [diff] [blame] | 14 | .. index:: | 
 | 15 |    single: configuration information | 
 | 16 |  | 
| Raymond Hettinger | a199368 | 2011-01-27 01:20:32 +0000 | [diff] [blame] | 17 | -------------- | 
 | 18 |  | 
| Tarek Ziadé | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 19 | The :mod:`sysconfig` module provides access to Python's configuration | 
| Tarek Ziadé | 667882f | 2010-02-11 20:47:18 +0000 | [diff] [blame] | 20 | information like the list of installation paths and the configuration variables | 
 | 21 | relevant for the current platform. | 
| Tarek Ziadé | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 22 |  | 
 | 23 | Configuration variables | 
 | 24 | ----------------------- | 
 | 25 |  | 
| Benjamin Peterson | d7c3ed5 | 2010-06-27 22:32:30 +0000 | [diff] [blame] | 26 | A Python distribution contains a :file:`Makefile` and a :file:`pyconfig.h` | 
 | 27 | header file that are necessary to build both the Python binary itself and | 
 | 28 | third-party C extensions compiled using :mod:`distutils`. | 
| Tarek Ziadé | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 29 |  | 
| Tarek Ziadé | 667882f | 2010-02-11 20:47:18 +0000 | [diff] [blame] | 30 | :mod:`sysconfig` puts all variables found in these files in a dictionary that | 
 | 31 | can be accessed using :func:`get_config_vars` or :func:`get_config_var`. | 
| Tarek Ziadé | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 32 |  | 
 | 33 | Notice that on Windows, it's a much smaller set. | 
 | 34 |  | 
 | 35 | .. function:: get_config_vars(\*args) | 
 | 36 |  | 
| Tarek Ziadé | 667882f | 2010-02-11 20:47:18 +0000 | [diff] [blame] | 37 |    With no arguments, return a dictionary of all configuration variables | 
 | 38 |    relevant for the current platform. | 
| Tarek Ziadé | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 39 |  | 
| Tarek Ziadé | 667882f | 2010-02-11 20:47:18 +0000 | [diff] [blame] | 40 |    With arguments, return a list of values that result from looking up each | 
 | 41 |    argument in the configuration variable dictionary. | 
| Tarek Ziadé | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 42 |  | 
| Tarek Ziadé | 667882f | 2010-02-11 20:47:18 +0000 | [diff] [blame] | 43 |    For each argument, if the value is not found, return ``None``. | 
 | 44 |  | 
| Tarek Ziadé | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 45 |  | 
 | 46 | .. function:: get_config_var(name) | 
 | 47 |  | 
 | 48 |    Return the value of a single variable *name*. Equivalent to | 
| Tarek Ziadé | 667882f | 2010-02-11 20:47:18 +0000 | [diff] [blame] | 49 |    ``get_config_vars().get(name)``. | 
| Tarek Ziadé | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 50 |  | 
| Tarek Ziadé | 667882f | 2010-02-11 20:47:18 +0000 | [diff] [blame] | 51 |    If *name* is not found, return ``None``. | 
| Tarek Ziadé | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 52 |  | 
 | 53 | Example of usage:: | 
 | 54 |  | 
| Tarek Ziadé | 667882f | 2010-02-11 20:47:18 +0000 | [diff] [blame] | 55 |    >>> 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é | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 62 |  | 
 | 63 |  | 
 | 64 | Installation paths | 
 | 65 | ------------------ | 
 | 66 |  | 
| Tarek Ziadé | 667882f | 2010-02-11 20:47:18 +0000 | [diff] [blame] | 67 | Python uses an installation scheme that differs depending on the platform and on | 
 | 68 | the installation options.  These schemes are stored in :mod:`sysconfig` under | 
 | 69 | unique identifiers based on the value returned by :const:`os.name`. | 
| Tarek Ziadé | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 70 |  | 
 | 71 | Every new component that is installed using :mod:`distutils` or a | 
| Tarek Ziadé | 667882f | 2010-02-11 20:47:18 +0000 | [diff] [blame] | 72 | Distutils-based system will follow the same scheme to copy its file in the right | 
 | 73 | places. | 
| Tarek Ziadé | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 74 |  | 
 | 75 | Python currently supports seven schemes: | 
 | 76 |  | 
| Tarek Ziadé | 667882f | 2010-02-11 20:47:18 +0000 | [diff] [blame] | 77 | - *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é | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 81 |   Distutils with a specific home prefix. | 
| Tarek Ziadé | 667882f | 2010-02-11 20:47:18 +0000 | [diff] [blame] | 82 | - *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é | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 84 |   located under the user home directory. | 
| Tarek Ziadé | 667882f | 2010-02-11 20:47:18 +0000 | [diff] [blame] | 85 | - *nt*: scheme for NT platforms like Windows. | 
 | 86 | - *nt_user*: scheme for NT platforms, when the *user* option is used. | 
| Tarek Ziadé | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 87 |  | 
 | 88 | Each scheme is itself composed of a series of paths and each path has a unique | 
| Tarek Ziadé | 667882f | 2010-02-11 20:47:18 +0000 | [diff] [blame] | 89 | identifier.  Python currently uses eight paths: | 
| Tarek Ziadé | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 90 |  | 
| Tarek Ziadé | 667882f | 2010-02-11 20:47:18 +0000 | [diff] [blame] | 91 | - *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é | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 101 |  | 
| Tarek Ziadé | 667882f | 2010-02-11 20:47:18 +0000 | [diff] [blame] | 102 | :mod:`sysconfig` provides some functions to determine these paths. | 
| Tarek Ziadé | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 103 |  | 
 | 104 | .. function:: get_scheme_names() | 
 | 105 |  | 
 | 106 |    Return a tuple containing all schemes currently supported in | 
 | 107 |    :mod:`sysconfig`. | 
 | 108 |  | 
| Tarek Ziadé | 667882f | 2010-02-11 20:47:18 +0000 | [diff] [blame] | 109 |  | 
| Tarek Ziadé | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 110 | .. 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é | 667882f | 2010-02-11 20:47:18 +0000 | [diff] [blame] | 123 |    :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é | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 126 |  | 
 | 127 |    :func:`get_path` will use the variables returned by :func:`get_config_vars` | 
| Tarek Ziadé | 667882f | 2010-02-11 20:47:18 +0000 | [diff] [blame] | 128 |    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é | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 130 |  | 
 | 131 |    If *scheme* is provided, it must be a value from the list returned by | 
| Éric Araujo | 2bddc53 | 2011-11-29 16:34:58 +0100 | [diff] [blame] | 132 |    :func:`get_scheme_names`.  Otherwise, the default scheme for the current | 
| Tarek Ziadé | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 133 |    platform is used. | 
 | 134 |  | 
| Tarek Ziadé | 667882f | 2010-02-11 20:47:18 +0000 | [diff] [blame] | 135 |    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é | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 137 |  | 
| Tarek Ziadé | 667882f | 2010-02-11 20:47:18 +0000 | [diff] [blame] | 138 |    If *expand* is set to ``False``, the path will not be expanded using the | 
 | 139 |    variables. | 
| Tarek Ziadé | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 140 |  | 
| Tarek Ziadé | 667882f | 2010-02-11 20:47:18 +0000 | [diff] [blame] | 141 |    If *name* is not found, return ``None``. | 
| Tarek Ziadé | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 142 |  | 
 | 143 |  | 
 | 144 | .. function:: get_paths([scheme, [vars, [expand]]]) | 
 | 145 |  | 
| Tarek Ziadé | 667882f | 2010-02-11 20:47:18 +0000 | [diff] [blame] | 146 |    Return a dictionary containing all installation paths corresponding to an | 
| Tarek Ziadé | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 147 |    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é | 667882f | 2010-02-11 20:47:18 +0000 | [diff] [blame] | 152 |    If *vars* is provided, it must be a dictionary of variables that will | 
 | 153 |    update the dictionary used to expand the paths. | 
| Tarek Ziadé | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 154 |  | 
| Serhiy Storchaka | 4adf01c | 2016-10-19 18:30:05 +0300 | [diff] [blame] | 155 |    If *expand* is set to false, the paths will not be expanded. | 
| Tarek Ziadé | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 156 |  | 
 | 157 |    If *scheme* is not an existing scheme, :func:`get_paths` will raise a | 
 | 158 |    :exc:`KeyError`. | 
 | 159 |  | 
 | 160 |  | 
 | 161 | Other functions | 
 | 162 | --------------- | 
 | 163 |  | 
 | 164 | .. function:: get_python_version() | 
 | 165 |  | 
| Tarek Ziadé | 667882f | 2010-02-11 20:47:18 +0000 | [diff] [blame] | 166 |    Return the ``MAJOR.MINOR`` Python version number as a string.  Similar to | 
| Serhiy Storchaka | 885bdc4 | 2016-02-11 13:10:36 +0200 | [diff] [blame] | 167 |    ``'%d.%d' % sys.version_info[:2]``. | 
| Tarek Ziadé | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 168 |  | 
| Tarek Ziadé | 667882f | 2010-02-11 20:47:18 +0000 | [diff] [blame] | 169 |  | 
| Tarek Ziadé | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 170 | .. 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é | 667882f | 2010-02-11 20:47:18 +0000 | [diff] [blame] | 175 |    platform-specific built distributions.  Typically includes the OS name and | 
 | 176 |    version and the architecture (as supplied by :func:`os.uname`), although the | 
 | 177 |    exact information included depends on the OS; e.g. for IRIX the architecture | 
 | 178 |    isn't particularly important (IRIX only runs on SGI hardware), but for Linux | 
 | 179 |    the kernel version isn't particularly important. | 
| Tarek Ziadé | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 180 |  | 
 | 181 |    Examples of returned values: | 
 | 182 |  | 
 | 183 |    - linux-i586 | 
 | 184 |    - linux-alpha (?) | 
 | 185 |    - solaris-2.6-sun4u | 
 | 186 |    - irix-5.3 | 
 | 187 |    - irix64-6.2 | 
 | 188 |  | 
 | 189 |    Windows will return one of: | 
 | 190 |  | 
 | 191 |    - win-amd64 (64bit Windows on AMD64 (aka x86_64, Intel64, EM64T, etc) | 
 | 192 |    - win-ia64 (64bit Windows on Itanium) | 
 | 193 |    - win32 (all others - specifically, sys.platform is returned) | 
 | 194 |  | 
| Tarek Ziadé | 667882f | 2010-02-11 20:47:18 +0000 | [diff] [blame] | 195 |    Mac OS X can return: | 
| Tarek Ziadé | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 196 |  | 
 | 197 |    - macosx-10.6-ppc | 
 | 198 |    - macosx-10.4-ppc64 | 
 | 199 |    - macosx-10.3-i386 | 
 | 200 |    - macosx-10.4-fat | 
 | 201 |  | 
| Tarek Ziadé | 667882f | 2010-02-11 20:47:18 +0000 | [diff] [blame] | 202 |    For other non-POSIX platforms, currently just returns :data:`sys.platform`. | 
| Tarek Ziadé | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 203 |  | 
 | 204 |  | 
| Tarek Ziadé | 667882f | 2010-02-11 20:47:18 +0000 | [diff] [blame] | 205 | .. function:: is_python_build() | 
| Tarek Ziadé | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 206 |  | 
| Vinay Sajip | 37cac76 | 2016-08-25 15:13:24 +0100 | [diff] [blame] | 207 |    Return ``True`` if the running Python interpreter was built from source and | 
 | 208 |    is being run from its built location, and not from a location resulting from | 
 | 209 |    e.g. running ``make install`` or installing via a binary installer. | 
| Tarek Ziadé | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 210 |  | 
 | 211 |  | 
| Tarek Ziadé | 667882f | 2010-02-11 20:47:18 +0000 | [diff] [blame] | 212 | .. function:: parse_config_h(fp[, vars]) | 
| Tarek Ziadé | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 213 |  | 
| Tarek Ziadé | 667882f | 2010-02-11 20:47:18 +0000 | [diff] [blame] | 214 |    Parse a :file:`config.h`\-style file. | 
| Tarek Ziadé | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 215 |  | 
| Tarek Ziadé | 667882f | 2010-02-11 20:47:18 +0000 | [diff] [blame] | 216 |    *fp* is a file-like object pointing to the :file:`config.h`\-like file. | 
| Tarek Ziadé | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 217 |  | 
 | 218 |    A dictionary containing name/value pairs is returned.  If an optional | 
| Tarek Ziadé | 667882f | 2010-02-11 20:47:18 +0000 | [diff] [blame] | 219 |    dictionary is passed in as the second argument, it is used instead of a new | 
 | 220 |    dictionary, and updated with the values read in the file. | 
| Tarek Ziadé | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 221 |  | 
 | 222 |  | 
| Tarek Ziadé | 667882f | 2010-02-11 20:47:18 +0000 | [diff] [blame] | 223 | .. function:: get_config_h_filename() | 
| Tarek Ziadé | 1875570 | 2010-02-02 23:17:47 +0000 | [diff] [blame] | 224 |  | 
| Tarek Ziadé | 667882f | 2010-02-11 20:47:18 +0000 | [diff] [blame] | 225 |    Return the path of :file:`pyconfig.h`. | 
| Tarek Ziadé | a751499 | 2010-05-25 09:44:36 +0000 | [diff] [blame] | 226 |  | 
| Barry Warsaw | ebbef6f | 2010-09-20 15:29:53 +0000 | [diff] [blame] | 227 | .. function:: get_makefile_filename() | 
 | 228 |  | 
 | 229 |    Return the path of :file:`Makefile`. | 
 | 230 |  | 
| Tarek Ziadé | a751499 | 2010-05-25 09:44:36 +0000 | [diff] [blame] | 231 | Using :mod:`sysconfig` as a script | 
 | 232 | ---------------------------------- | 
 | 233 |  | 
| Martin Panter | 1050d2d | 2016-07-26 11:18:21 +0200 | [diff] [blame] | 234 | You can use :mod:`sysconfig` as a script with Python's *-m* option: | 
 | 235 |  | 
 | 236 | .. code-block:: shell-session | 
| Tarek Ziadé | a751499 | 2010-05-25 09:44:36 +0000 | [diff] [blame] | 237 |  | 
 | 238 |     $ python -m sysconfig | 
 | 239 |     Platform: "macosx-10.4-i386" | 
 | 240 |     Python version: "3.2" | 
 | 241 |     Current installation scheme: "posix_prefix" | 
 | 242 |  | 
 | 243 |     Paths: | 
 | 244 |             data = "/usr/local" | 
 | 245 |             include = "/Users/tarek/Dev/svn.python.org/py3k/Include" | 
 | 246 |             platinclude = "." | 
 | 247 |             platlib = "/usr/local/lib/python3.2/site-packages" | 
 | 248 |             platstdlib = "/usr/local/lib/python3.2" | 
 | 249 |             purelib = "/usr/local/lib/python3.2/site-packages" | 
 | 250 |             scripts = "/usr/local/bin" | 
 | 251 |             stdlib = "/usr/local/lib/python3.2" | 
 | 252 |  | 
 | 253 |     Variables: | 
 | 254 |             AC_APPLE_UNIVERSAL_BUILD = "0" | 
 | 255 |             AIX_GENUINE_CPLUSPLUS = "0" | 
 | 256 |             AR = "ar" | 
 | 257 |             ARFLAGS = "rc" | 
 | 258 |             ASDLGEN = "./Parser/asdl_c.py" | 
 | 259 |             ... | 
 | 260 |  | 
 | 261 | This call will print in the standard output the information returned by | 
 | 262 | :func:`get_platform`, :func:`get_python_version`, :func:`get_path` and | 
 | 263 | :func:`get_config_vars`. |