source: python/trunk/Doc/library/sysconfig.rst

Last change on this file was 394, checked in by dmik, 11 years ago

python: Use Posix directory scheme everywhere on OS/2.

  • Property svn:eol-style set to native
File size: 7.4 KB
RevLine 
[388]1: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>
8.. index::
9 single: configuration information
10
11.. versionadded:: 2.7
12
13**Source code:** :source:`Lib/sysconfig.py`
14
15--------------
16
17The :mod:`sysconfig` module provides access to Python's configuration
18information like the list of installation paths and the configuration variables
19relevant for the current platform.
20
21Configuration variables
22-----------------------
23
24A Python distribution contains a :file:`Makefile` and a :file:`pyconfig.h`
25header file that are necessary to build both the Python binary itself and
26third-party C extensions compiled using :mod:`distutils`.
27
28:mod:`sysconfig` puts all variables found in these files in a dictionary that
29can be accessed using :func:`get_config_vars` or :func:`get_config_var`.
30
31Notice that on Windows, it's a much smaller set.
32
33.. function:: get_config_vars(\*args)
34
35 With no arguments, return a dictionary of all configuration variables
36 relevant for the current platform.
37
38 With arguments, return a list of values that result from looking up each
39 argument in the configuration variable dictionary.
40
41 For each argument, if the value is not found, return ``None``.
42
43
44.. function:: get_config_var(name)
45
46 Return the value of a single variable *name*. Equivalent to
47 ``get_config_vars().get(name)``.
48
49 If *name* is not found, return ``None``.
50
51Example of usage::
52
53 >>> import sysconfig
54 >>> sysconfig.get_config_var('Py_ENABLE_SHARED')
55 0
56 >>> sysconfig.get_config_var('LIBDIR')
57 '/usr/local/lib'
58 >>> sysconfig.get_config_vars('AR', 'CXX')
59 ['ar', 'g++']
60
61
62Installation paths
63------------------
64
65Python uses an installation scheme that differs depending on the platform and on
66the installation options. These schemes are stored in :mod:`sysconfig` under
67unique identifiers based on the value returned by :const:`os.name`.
68
69Every new component that is installed using :mod:`distutils` or a
70Distutils-based system will follow the same scheme to copy its file in the right
71places.
72
73Python currently supports seven schemes:
74
75- *posix_prefix*: scheme for Posix platforms like Linux or Mac OS X. This is
76 the default scheme used when Python or a component is installed.
77- *posix_home*: scheme for Posix platforms used when a *home* option is used
78 upon installation. This scheme is used when a component is installed through
79 Distutils with a specific home prefix.
80- *posix_user*: scheme for Posix platforms used when a component is installed
81 through Distutils and the *user* option is used. This scheme defines paths
82 located under the user home directory.
83- *nt*: scheme for NT platforms like Windows.
84- *nt_user*: scheme for NT platforms, when the *user* option is used.
85- *os2*: scheme for OS/2 platforms.
[394]86- *os2_user*: scheme for OS/2 patforms, when the *user* option is used.
[388]87
88Each scheme is itself composed of a series of paths and each path has a unique
89identifier. Python currently uses eight paths:
90
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.
101
102:mod:`sysconfig` provides some functions to determine these paths.
103
104.. function:: get_scheme_names()
105
106 Return a tuple containing all schemes currently supported in
107 :mod:`sysconfig`.
108
109
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
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``.
126
127 :func:`get_path` will use the variables returned by :func:`get_config_vars`
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.
130
131 If *scheme* is provided, it must be a value from the list returned by
132 :func:`get_scheme_names`. Otherwise, the default scheme for the current
133 platform is used.
134
135 If *vars* is provided, it must be a dictionary of variables that will update
136 the dictionary return by :func:`get_config_vars`.
137
138 If *expand* is set to ``False``, the path will not be expanded using the
139 variables.
140
141 If *name* is not found, return ``None``.
142
143
144.. function:: get_paths([scheme, [vars, [expand]]])
145
146 Return a dictionary containing all installation paths corresponding to an
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
152 If *vars* is provided, it must be a dictionary of variables that will
153 update the dictionary used to expand the paths.
154
155 If *expand* is set to False, the paths will not be expanded.
156
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
166 Return the ``MAJOR.MINOR`` Python version number as a string. Similar to
167 ``sys.version[:3]``.
168
169
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
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.
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
195 Mac OS X can return:
196
197 - macosx-10.6-ppc
198 - macosx-10.4-ppc64
199 - macosx-10.3-i386
200 - macosx-10.4-fat
201
202 For other non-POSIX platforms, currently just returns :data:`sys.platform`.
203
204
205.. function:: is_python_build()
206
207 Return ``True`` if the current Python installation was built from source.
208
209
210.. function:: parse_config_h(fp[, vars])
211
212 Parse a :file:`config.h`\-style file.
213
214 *fp* is a file-like object pointing to the :file:`config.h`\-like file.
215
216 A dictionary containing name/value pairs is returned. If an optional
217 dictionary is passed in as the second argument, it is used instead of a new
218 dictionary, and updated with the values read in the file.
219
220
221.. function:: get_config_h_filename()
222
223 Return the path of :file:`pyconfig.h`.
Note: See TracBrowser for help on using the repository browser.