OXIESEC PANEL
- Current Dir:
/
/
usr
/
lib
/
python3.7
Server IP: 139.59.38.164
Upload:
Create Dir:
Name
Size
Modified
Perms
📁
..
-
10/28/2024 06:50:42 AM
rwxr-xr-x
📄
LICENSE.txt
12.47 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
__future__.py
4.98 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
__phello__.foo.py
64 bytes
12/09/2021 05:04:37 PM
rw-r--r--
📁
__pycache__
-
05/09/2024 06:49:08 AM
rwxr-xr-x
📄
_bootlocale.py
1.76 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
_collections_abc.py
25.8 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
_compat_pickle.py
8.54 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
_compression.py
5.21 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
_dummy_thread.py
5.89 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
_markupbase.py
14.26 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
_osx_support.py
18.67 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
_py_abc.py
6.04 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
_pydecimal.py
223.18 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
_pyio.py
89.33 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
_sitebuiltins.py
3.04 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
_strptime.py
24.91 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
_sysconfigdata_m_linux_x86_64-linux-gnu.py
24.06 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
_threading_local.py
7.04 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
_weakrefset.py
5.55 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
abc.py
5.45 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
aifc.py
32.04 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
antigravity.py
477 bytes
12/09/2021 05:04:37 PM
rw-r--r--
📄
argparse.py
93.31 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
ast.py
12.56 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
asynchat.py
11.06 KB
12/09/2021 05:04:37 PM
rw-r--r--
📁
asyncio
-
05/09/2024 06:49:07 AM
rwxr-xr-x
📄
asyncore.py
19.65 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
base64.py
19.9 KB
12/09/2021 05:04:37 PM
rwxr-xr-x
📄
bdb.py
31.18 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
binhex.py
13.63 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
bisect.py
2.5 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
bz2.py
12.12 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
cProfile.py
6.09 KB
12/09/2021 05:04:37 PM
rwxr-xr-x
📄
calendar.py
24.24 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
cgi.py
33.84 KB
12/09/2021 05:04:37 PM
rwxr-xr-x
📄
cgitb.py
11.74 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
chunk.py
5.31 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
cmd.py
14.51 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
code.py
10.37 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
codecs.py
35.68 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
codeop.py
5.85 KB
12/09/2021 05:04:37 PM
rw-r--r--
📁
collections
-
05/09/2024 06:49:07 AM
rwxr-xr-x
📄
colorsys.py
3.97 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
compileall.py
13.33 KB
12/09/2021 05:04:37 PM
rw-r--r--
📁
concurrent
-
05/09/2024 06:49:08 AM
rwxr-xr-x
📄
configparser.py
53.01 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
contextlib.py
24.18 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
contextvars.py
129 bytes
12/09/2021 05:04:37 PM
rw-r--r--
📄
copy.py
8.61 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
copyreg.py
6.85 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
crypt.py
3.27 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
csv.py
15.8 KB
12/09/2021 05:04:37 PM
rw-r--r--
📁
ctypes
-
05/09/2024 06:49:08 AM
rwxr-xr-x
📁
curses
-
05/09/2024 06:49:08 AM
rwxr-xr-x
📄
dataclasses.py
47.7 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
datetime.py
84.52 KB
12/09/2021 05:04:37 PM
rw-r--r--
📁
dbm
-
05/09/2024 06:49:08 AM
rwxr-xr-x
📄
decimal.py
320 bytes
12/09/2021 05:04:37 PM
rw-r--r--
📄
difflib.py
82.41 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
dis.py
19.42 KB
12/09/2021 05:04:37 PM
rw-r--r--
📁
distutils
-
05/09/2024 06:57:52 AM
rwxr-xr-x
📄
doctest.py
101.84 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
dummy_threading.py
2.75 KB
12/09/2021 05:04:37 PM
rw-r--r--
📁
email
-
05/09/2024 06:49:08 AM
rwxr-xr-x
📁
encodings
-
05/09/2024 06:49:07 AM
rwxr-xr-x
📁
ensurepip
-
05/09/2024 07:26:24 AM
rwxr-xr-x
📄
enum.py
33.96 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
filecmp.py
9.6 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
fileinput.py
14.28 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
fnmatch.py
3.96 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
formatter.py
14.79 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
fractions.py
23.08 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
ftplib.py
34.43 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
functools.py
32.16 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
genericpath.py
4.8 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
getopt.py
7.31 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
getpass.py
5.85 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
gettext.py
21.87 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
glob.py
5.51 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
gzip.py
19.86 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
hashlib.py
9.31 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
heapq.py
22.48 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
hmac.py
6.36 KB
12/09/2021 05:04:37 PM
rw-r--r--
📁
html
-
05/09/2024 06:49:08 AM
rwxr-xr-x
📁
http
-
05/09/2024 06:49:08 AM
rwxr-xr-x
📄
imaplib.py
52.04 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
imghdr.py
3.71 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
imp.py
10.29 KB
12/09/2021 05:04:37 PM
rw-r--r--
📁
importlib
-
05/09/2024 06:49:07 AM
rwxr-xr-x
📄
inspect.py
114.88 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
io.py
3.43 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
ipaddress.py
71.84 KB
12/09/2021 05:04:37 PM
rw-r--r--
📁
json
-
05/09/2024 06:49:08 AM
rwxr-xr-x
📄
keyword.py
2.19 KB
12/09/2021 05:04:37 PM
rwxr-xr-x
📁
lib-dynload
-
05/09/2024 07:13:53 AM
rwxr-xr-x
📁
lib2to3
-
05/09/2024 06:58:00 AM
rwxr-xr-x
📄
linecache.py
5.19 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
locale.py
76.36 KB
12/09/2021 05:04:37 PM
rw-r--r--
📁
logging
-
05/09/2024 06:49:07 AM
rwxr-xr-x
📄
lzma.py
12.68 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
macpath.py
5.98 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
mailbox.py
76.81 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
mailcap.py
7.91 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
mimetypes.py
20.99 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
modulefinder.py
22.5 KB
12/09/2021 05:04:37 PM
rw-r--r--
📁
multiprocessing
-
05/09/2024 06:49:08 AM
rwxr-xr-x
📄
netrc.py
5.44 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
nntplib.py
42.08 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
ntpath.py
21.82 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
nturl2path.py
2.52 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
numbers.py
10 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
opcode.py
5.69 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
operator.py
10.61 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
optparse.py
58.96 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
os.py
36.9 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
pathlib.py
48.54 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
pdb.py
61.03 KB
12/09/2021 05:04:37 PM
rwxr-xr-x
📄
pickle.py
56.63 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
pickletools.py
89.08 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
pipes.py
8.71 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
pkgutil.py
20.96 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
platform.py
46.84 KB
12/09/2021 05:04:37 PM
rwxr-xr-x
📄
plistlib.py
29.2 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
poplib.py
14.61 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
posixpath.py
15.4 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
pprint.py
20.39 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
profile.py
21.95 KB
12/09/2021 05:04:37 PM
rwxr-xr-x
📄
pstats.py
26.67 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
pty.py
4.65 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
py_compile.py
7.81 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
pyclbr.py
14.78 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
pydoc.py
104.52 KB
12/09/2021 05:04:37 PM
rwxr-xr-x
📁
pydoc_data
-
05/09/2024 06:49:08 AM
rwxr-xr-x
📄
queue.py
11.09 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
quopri.py
7.08 KB
12/09/2021 05:04:37 PM
rwxr-xr-x
📄
random.py
26.91 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
re.py
14.84 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
reprlib.py
5.14 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
rlcompleter.py
6.93 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
runpy.py
11.68 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
sched.py
6.29 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
secrets.py
1.99 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
selectors.py
18.13 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
shelve.py
8.33 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
shlex.py
12.74 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
shutil.py
40.97 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
signal.py
2.07 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
site.py
21.79 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
sitecustomize.py
155 bytes
12/09/2021 05:04:37 PM
rw-r--r--
📄
smtpd.py
33.9 KB
12/09/2021 05:04:37 PM
rwxr-xr-x
📄
smtplib.py
43.17 KB
12/09/2021 05:04:37 PM
rwxr-xr-x
📄
sndhdr.py
6.92 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
socket.py
26.72 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
socketserver.py
26.29 KB
12/09/2021 05:04:37 PM
rw-r--r--
📁
sqlite3
-
05/09/2024 06:49:08 AM
rwxr-xr-x
📄
sre_compile.py
26.24 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
sre_constants.py
7.01 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
sre_parse.py
38.24 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
ssl.py
44.43 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
stat.py
4.92 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
statistics.py
20.17 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
string.py
11.29 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
stringprep.py
12.61 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
struct.py
257 bytes
12/09/2021 05:04:37 PM
rw-r--r--
📄
subprocess.py
70 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
sunau.py
17.94 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
symbol.py
2.08 KB
12/09/2021 05:04:37 PM
rwxr-xr-x
📄
symtable.py
7.1 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
sysconfig.py
23.94 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
tabnanny.py
11.14 KB
12/09/2021 05:04:37 PM
rwxr-xr-x
📄
tarfile.py
90.45 KB
12/09/2021 05:04:37 PM
rwxr-xr-x
📄
telnetlib.py
22.59 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
tempfile.py
31.06 KB
12/09/2021 05:04:37 PM
rw-r--r--
📁
test
-
05/09/2024 06:49:08 AM
rwxr-xr-x
📄
textwrap.py
18.95 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
this.py
1003 bytes
12/09/2021 05:04:37 PM
rw-r--r--
📄
threading.py
47.9 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
timeit.py
13.13 KB
12/09/2021 05:04:37 PM
rwxr-xr-x
📄
token.py
3.67 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
tokenize.py
26.4 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
trace.py
28.3 KB
12/09/2021 05:04:37 PM
rwxr-xr-x
📄
traceback.py
22.89 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
tracemalloc.py
16.68 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
tty.py
879 bytes
12/09/2021 05:04:37 PM
rw-r--r--
📄
turtle.py
140.24 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
types.py
9.67 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
typing.py
54.37 KB
12/09/2021 05:04:37 PM
rw-r--r--
📁
unittest
-
05/09/2024 06:49:08 AM
rwxr-xr-x
📁
urllib
-
05/09/2024 06:49:08 AM
rwxr-xr-x
📄
uu.py
6.65 KB
12/09/2021 05:04:37 PM
rwxr-xr-x
📄
uuid.py
28.83 KB
12/09/2021 05:04:37 PM
rw-r--r--
📁
venv
-
05/09/2024 06:49:08 AM
rwxr-xr-x
📄
warnings.py
19.77 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
wave.py
17.8 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
weakref.py
21 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
webbrowser.py
22.55 KB
12/09/2021 05:04:37 PM
rwxr-xr-x
📁
wsgiref
-
05/09/2024 06:49:08 AM
rwxr-xr-x
📄
xdrlib.py
5.77 KB
12/09/2021 05:04:37 PM
rw-r--r--
📁
xml
-
05/09/2024 06:49:08 AM
rwxr-xr-x
📁
xmlrpc
-
05/09/2024 06:49:08 AM
rwxr-xr-x
📄
zipapp.py
7.36 KB
12/09/2021 05:04:37 PM
rw-r--r--
📄
zipfile.py
78.63 KB
12/09/2021 05:04:37 PM
rw-r--r--
Editing: sysconfig.py
Close
"""Access to Python's configuration information.""" import os import sys from os.path import pardir, realpath __all__ = [ 'get_config_h_filename', 'get_config_var', 'get_config_vars', 'get_makefile_filename', 'get_path', 'get_path_names', 'get_paths', 'get_platform', 'get_python_version', 'get_scheme_names', 'parse_config_h', ] _INSTALL_SCHEMES = { 'posix_prefix': { 'stdlib': '{installed_base}/lib/python{py_version_short}', 'platstdlib': '{platbase}/lib/python{py_version_short}', 'purelib': '{base}/lib/python{py_version_short}/site-packages', 'platlib': '{platbase}/lib/python{py_version_short}/site-packages', 'include': '{installed_base}/include/python{py_version_short}{abiflags}', 'platinclude': '{installed_platbase}/include/python{py_version_short}{abiflags}', 'scripts': '{base}/bin', 'data': '{base}', }, 'posix_home': { 'stdlib': '{installed_base}/lib/python', 'platstdlib': '{base}/lib/python', 'purelib': '{base}/lib/python', 'platlib': '{base}/lib/python', 'include': '{installed_base}/include/python', 'platinclude': '{installed_base}/include/python', 'scripts': '{base}/bin', 'data': '{base}', }, 'nt': { 'stdlib': '{installed_base}/Lib', 'platstdlib': '{base}/Lib', 'purelib': '{base}/Lib/site-packages', 'platlib': '{base}/Lib/site-packages', 'include': '{installed_base}/Include', 'platinclude': '{installed_base}/Include', 'scripts': '{base}/Scripts', 'data': '{base}', }, # NOTE: When modifying "purelib" scheme, update site._get_path() too. 'nt_user': { 'stdlib': '{userbase}/Python{py_version_nodot}', 'platstdlib': '{userbase}/Python{py_version_nodot}', 'purelib': '{userbase}/Python{py_version_nodot}/site-packages', 'platlib': '{userbase}/Python{py_version_nodot}/site-packages', 'include': '{userbase}/Python{py_version_nodot}/Include', 'scripts': '{userbase}/Python{py_version_nodot}/Scripts', 'data': '{userbase}', }, 'posix_user': { 'stdlib': '{userbase}/lib/python{py_version_short}', 'platstdlib': '{userbase}/lib/python{py_version_short}', 'purelib': '{userbase}/lib/python{py_version_short}/site-packages', 'platlib': '{userbase}/lib/python{py_version_short}/site-packages', 'include': '{userbase}/include/python{py_version_short}', 'scripts': '{userbase}/bin', 'data': '{userbase}', }, 'osx_framework_user': { 'stdlib': '{userbase}/lib/python', 'platstdlib': '{userbase}/lib/python', 'purelib': '{userbase}/lib/python/site-packages', 'platlib': '{userbase}/lib/python/site-packages', 'include': '{userbase}/include', 'scripts': '{userbase}/bin', 'data': '{userbase}', }, } _SCHEME_KEYS = ('stdlib', 'platstdlib', 'purelib', 'platlib', 'include', 'scripts', 'data') # FIXME don't rely on sys.version here, its format is an implementation detail # of CPython, use sys.version_info or sys.hexversion _PY_VERSION = sys.version.split()[0] _PY_VERSION_SHORT = '%d.%d' % sys.version_info[:2] _PY_VERSION_SHORT_NO_DOT = '%d%d' % sys.version_info[:2] _PREFIX = os.path.normpath(sys.prefix) _BASE_PREFIX = os.path.normpath(sys.base_prefix) _EXEC_PREFIX = os.path.normpath(sys.exec_prefix) _BASE_EXEC_PREFIX = os.path.normpath(sys.base_exec_prefix) _CONFIG_VARS = None _USER_BASE = None def _safe_realpath(path): try: return realpath(path) except OSError: return path if sys.executable: _PROJECT_BASE = os.path.dirname(_safe_realpath(sys.executable)) else: # sys.executable can be empty if argv[0] has been changed and Python is # unable to retrieve the real program name _PROJECT_BASE = _safe_realpath(os.getcwd()) if (os.name == 'nt' and _PROJECT_BASE.lower().endswith(('\\pcbuild\\win32', '\\pcbuild\\amd64'))): _PROJECT_BASE = _safe_realpath(os.path.join(_PROJECT_BASE, pardir, pardir)) # set for cross builds if "_PYTHON_PROJECT_BASE" in os.environ: _PROJECT_BASE = _safe_realpath(os.environ["_PYTHON_PROJECT_BASE"]) def _is_python_source_dir(d): for fn in ("Setup.dist", "Setup.local"): if os.path.isfile(os.path.join(d, "Modules", fn)): return True return False _sys_home = getattr(sys, '_home', None) if os.name == 'nt': def _fix_pcbuild(d): if d and os.path.normcase(d).startswith( os.path.normcase(os.path.join(_PREFIX, "PCbuild"))): return _PREFIX return d _PROJECT_BASE = _fix_pcbuild(_PROJECT_BASE) _sys_home = _fix_pcbuild(_sys_home) def is_python_build(check_home=False): if check_home and _sys_home: return _is_python_source_dir(_sys_home) return _is_python_source_dir(_PROJECT_BASE) _PYTHON_BUILD = is_python_build(True) if _PYTHON_BUILD: for scheme in ('posix_prefix', 'posix_home'): _INSTALL_SCHEMES[scheme]['include'] = '{srcdir}/Include' _INSTALL_SCHEMES[scheme]['platinclude'] = '{projectbase}/.' def _subst_vars(s, local_vars): try: return s.format(**local_vars) except KeyError: try: return s.format(**os.environ) except KeyError as var: raise AttributeError('{%s}' % var) from None def _extend_dict(target_dict, other_dict): target_keys = target_dict.keys() for key, value in other_dict.items(): if key in target_keys: continue target_dict[key] = value def _expand_vars(scheme, vars): res = {} if vars is None: vars = {} _extend_dict(vars, get_config_vars()) for key, value in _INSTALL_SCHEMES[scheme].items(): if os.name in ('posix', 'nt'): value = os.path.expanduser(value) res[key] = os.path.normpath(_subst_vars(value, vars)) return res def _get_default_scheme(): if os.name == 'posix': # the default scheme for posix is posix_prefix return 'posix_prefix' return os.name # NOTE: site.py has copy of this function. # Sync it when modify this function. def _getuserbase(): env_base = os.environ.get("PYTHONUSERBASE", None) if env_base: return env_base def joinuser(*args): return os.path.expanduser(os.path.join(*args)) if os.name == "nt": base = os.environ.get("APPDATA") or "~" return joinuser(base, "Python") if sys.platform == "darwin" and sys._framework: return joinuser("~", "Library", sys._framework, "%d.%d" % sys.version_info[:2]) return joinuser("~", ".local") def _parse_makefile(filename, vars=None): """Parse a Makefile-style file. A dictionary containing name/value pairs is returned. If an optional dictionary is passed in as the second argument, it is used instead of a new dictionary. """ # Regexes needed for parsing Makefile (and similar syntaxes, # like old-style Setup files). import re _variable_rx = re.compile(r"([a-zA-Z][a-zA-Z0-9_]+)\s*=\s*(.*)") _findvar1_rx = re.compile(r"\$\(([A-Za-z][A-Za-z0-9_]*)\)") _findvar2_rx = re.compile(r"\${([A-Za-z][A-Za-z0-9_]*)}") if vars is None: vars = {} done = {} notdone = {} with open(filename, errors="surrogateescape") as f: lines = f.readlines() for line in lines: if line.startswith('#') or line.strip() == '': continue m = _variable_rx.match(line) if m: n, v = m.group(1, 2) v = v.strip() # `$$' is a literal `$' in make tmpv = v.replace('$$', '') if "$" in tmpv: notdone[n] = v else: try: v = int(v) except ValueError: # insert literal `$' done[n] = v.replace('$$', '$') else: done[n] = v # do variable interpolation here variables = list(notdone.keys()) # Variables with a 'PY_' prefix in the makefile. These need to # be made available without that prefix through sysconfig. # Special care is needed to ensure that variable expansion works, even # if the expansion uses the name without a prefix. renamed_variables = ('CFLAGS', 'LDFLAGS', 'CPPFLAGS') while len(variables) > 0: for name in tuple(variables): value = notdone[name] m1 = _findvar1_rx.search(value) m2 = _findvar2_rx.search(value) if m1 and m2: m = m1 if m1.start() < m2.start() else m2 else: m = m1 if m1 else m2 if m is not None: n = m.group(1) found = True if n in done: item = str(done[n]) elif n in notdone: # get it on a subsequent round found = False elif n in os.environ: # do it like make: fall back to environment item = os.environ[n] elif n in renamed_variables: if (name.startswith('PY_') and name[3:] in renamed_variables): item = "" elif 'PY_' + n in notdone: found = False else: item = str(done['PY_' + n]) else: done[n] = item = "" if found: after = value[m.end():] value = value[:m.start()] + item + after if "$" in after: notdone[name] = value else: try: value = int(value) except ValueError: done[name] = value.strip() else: done[name] = value variables.remove(name) if name.startswith('PY_') \ and name[3:] in renamed_variables: name = name[3:] if name not in done: done[name] = value else: # bogus variable reference (e.g. "prefix=$/opt/python"); # just drop it since we can't deal done[name] = value variables.remove(name) # strip spurious spaces for k, v in done.items(): if isinstance(v, str): done[k] = v.strip() # save the results in the global dictionary vars.update(done) return vars def get_makefile_filename(): """Return the path of the Makefile.""" if _PYTHON_BUILD: return os.path.join(_sys_home or _PROJECT_BASE, "Makefile") if hasattr(sys, 'abiflags'): config_dir_name = 'config-%s%s' % (_PY_VERSION_SHORT, sys.abiflags) else: config_dir_name = 'config' if hasattr(sys.implementation, '_multiarch'): config_dir_name += '-%s' % sys.implementation._multiarch return os.path.join(get_path('stdlib'), config_dir_name, 'Makefile') def _get_sysconfigdata_name(): return os.environ.get('_PYTHON_SYSCONFIGDATA_NAME', '_sysconfigdata_{abi}_{platform}_{multiarch}'.format( abi=sys.abiflags, platform=sys.platform, multiarch=getattr(sys.implementation, '_multiarch', ''), )) def _generate_posix_vars(): """Generate the Python module containing build-time variables.""" import pprint vars = {} # load the installed Makefile: makefile = get_makefile_filename() try: _parse_makefile(makefile, vars) except OSError as e: msg = "invalid Python installation: unable to open %s" % makefile if hasattr(e, "strerror"): msg = msg + " (%s)" % e.strerror raise OSError(msg) # load the installed pyconfig.h: config_h = get_config_h_filename() try: with open(config_h) as f: parse_config_h(f, vars) except OSError as e: msg = "invalid Python installation: unable to open %s" % config_h if hasattr(e, "strerror"): msg = msg + " (%s)" % e.strerror raise OSError(msg) # On AIX, there are wrong paths to the linker scripts in the Makefile # -- these paths are relative to the Python source, but when installed # the scripts are in another directory. if _PYTHON_BUILD: vars['BLDSHARED'] = vars['LDSHARED'] # There's a chicken-and-egg situation on OS X with regards to the # _sysconfigdata module after the changes introduced by #15298: # get_config_vars() is called by get_platform() as part of the # `make pybuilddir.txt` target -- which is a precursor to the # _sysconfigdata.py module being constructed. Unfortunately, # get_config_vars() eventually calls _init_posix(), which attempts # to import _sysconfigdata, which we won't have built yet. In order # for _init_posix() to work, if we're on Darwin, just mock up the # _sysconfigdata module manually and populate it with the build vars. # This is more than sufficient for ensuring the subsequent call to # get_platform() succeeds. name = _get_sysconfigdata_name() if 'darwin' in sys.platform: import types module = types.ModuleType(name) module.build_time_vars = vars sys.modules[name] = module pybuilddir = 'build/lib.%s-%s' % (get_platform(), _PY_VERSION_SHORT) if hasattr(sys, "gettotalrefcount"): pybuilddir += '-pydebug' os.makedirs(pybuilddir, exist_ok=True) destfile = os.path.join(pybuilddir, name + '.py') with open(destfile, 'w', encoding='utf8') as f: f.write('# system configuration generated and used by' ' the sysconfig module\n') f.write('build_time_vars = ') pprint.pprint(vars, stream=f) # Create file used for sys.path fixup -- see Modules/getpath.c with open('pybuilddir.txt', 'w', encoding='ascii') as f: f.write(pybuilddir) def _init_posix(vars): """Initialize the module as appropriate for POSIX systems.""" # _sysconfigdata is generated at build time, see _generate_posix_vars() name = _get_sysconfigdata_name() _temp = __import__(name, globals(), locals(), ['build_time_vars'], 0) build_time_vars = _temp.build_time_vars vars.update(build_time_vars) def _init_non_posix(vars): """Initialize the module as appropriate for NT""" # set basic install directories vars['LIBDEST'] = get_path('stdlib') vars['BINLIBDEST'] = get_path('platstdlib') vars['INCLUDEPY'] = get_path('include') vars['EXT_SUFFIX'] = '.pyd' vars['EXE'] = '.exe' vars['VERSION'] = _PY_VERSION_SHORT_NO_DOT vars['BINDIR'] = os.path.dirname(_safe_realpath(sys.executable)) # # public APIs # def parse_config_h(fp, vars=None): """Parse a config.h-style file. A dictionary containing name/value pairs is returned. If an optional dictionary is passed in as the second argument, it is used instead of a new dictionary. """ if vars is None: vars = {} import re define_rx = re.compile("#define ([A-Z][A-Za-z0-9_]+) (.*)\n") undef_rx = re.compile("/[*] #undef ([A-Z][A-Za-z0-9_]+) [*]/\n") while True: line = fp.readline() if not line: break m = define_rx.match(line) if m: n, v = m.group(1, 2) try: v = int(v) except ValueError: pass vars[n] = v else: m = undef_rx.match(line) if m: vars[m.group(1)] = 0 return vars def get_config_h_filename(): """Return the path of pyconfig.h.""" if _PYTHON_BUILD: if os.name == "nt": inc_dir = os.path.join(_sys_home or _PROJECT_BASE, "PC") else: inc_dir = _sys_home or _PROJECT_BASE else: inc_dir = get_path('platinclude') return os.path.join(inc_dir, 'pyconfig.h') def get_scheme_names(): """Return a tuple containing the schemes names.""" return tuple(sorted(_INSTALL_SCHEMES)) def get_path_names(): """Return a tuple containing the paths names.""" return _SCHEME_KEYS def get_paths(scheme=_get_default_scheme(), vars=None, expand=True): """Return a mapping containing an install scheme. ``scheme`` is the install scheme name. If not provided, it will return the default scheme for the current platform. """ if expand: return _expand_vars(scheme, vars) else: return _INSTALL_SCHEMES[scheme] def get_path(name, scheme=_get_default_scheme(), vars=None, expand=True): """Return a path corresponding to the scheme. ``scheme`` is the install scheme name. """ return get_paths(scheme, vars, expand)[name] def get_config_vars(*args): """With no arguments, return a dictionary of all configuration variables relevant for the current platform. On Unix, this means every variable defined in Python's installed Makefile; On Windows it's a much smaller set. With arguments, return a list of values that result from looking up each argument in the configuration variable dictionary. """ global _CONFIG_VARS if _CONFIG_VARS is None: _CONFIG_VARS = {} # Normalized versions of prefix and exec_prefix are handy to have; # in fact, these are the standard versions used most places in the # Distutils. _CONFIG_VARS['prefix'] = _PREFIX _CONFIG_VARS['exec_prefix'] = _EXEC_PREFIX _CONFIG_VARS['py_version'] = _PY_VERSION _CONFIG_VARS['py_version_short'] = _PY_VERSION_SHORT _CONFIG_VARS['py_version_nodot'] = _PY_VERSION_SHORT_NO_DOT _CONFIG_VARS['installed_base'] = _BASE_PREFIX _CONFIG_VARS['base'] = _PREFIX _CONFIG_VARS['installed_platbase'] = _BASE_EXEC_PREFIX _CONFIG_VARS['platbase'] = _EXEC_PREFIX _CONFIG_VARS['projectbase'] = _PROJECT_BASE try: _CONFIG_VARS['abiflags'] = sys.abiflags except AttributeError: # sys.abiflags may not be defined on all platforms. _CONFIG_VARS['abiflags'] = '' if os.name == 'nt': _init_non_posix(_CONFIG_VARS) if os.name == 'posix': _init_posix(_CONFIG_VARS) # For backward compatibility, see issue19555 SO = _CONFIG_VARS.get('EXT_SUFFIX') if SO is not None: _CONFIG_VARS['SO'] = SO # Setting 'userbase' is done below the call to the # init function to enable using 'get_config_var' in # the init-function. _CONFIG_VARS['userbase'] = _getuserbase() multiarch = get_config_var('MULTIARCH') if multiarch: _CONFIG_VARS['multiarchsubdir'] = '/' + multiarch else: _CONFIG_VARS['multiarchsubdir'] = '' # Always convert srcdir to an absolute path srcdir = _CONFIG_VARS.get('srcdir', _PROJECT_BASE) if os.name == 'posix': if _PYTHON_BUILD: # If srcdir is a relative path (typically '.' or '..') # then it should be interpreted relative to the directory # containing Makefile. base = os.path.dirname(get_makefile_filename()) srcdir = os.path.join(base, srcdir) else: # srcdir is not meaningful since the installation is # spread about the filesystem. We choose the # directory containing the Makefile since we know it # exists. srcdir = os.path.dirname(get_makefile_filename()) _CONFIG_VARS['srcdir'] = _safe_realpath(srcdir) # OS X platforms require special customization to handle # multi-architecture, multi-os-version installers if sys.platform == 'darwin': import _osx_support _osx_support.customize_config_vars(_CONFIG_VARS) if args: vals = [] for name in args: vals.append(_CONFIG_VARS.get(name)) return vals else: return _CONFIG_VARS def get_config_var(name): """Return the value of a single variable using the dictionary returned by 'get_config_vars()'. Equivalent to get_config_vars().get(name) """ if name == 'SO': import warnings warnings.warn('SO is deprecated, use EXT_SUFFIX', DeprecationWarning, 2) return get_config_vars().get(name) def get_platform(): """Return a string that identifies the current platform. This is used mainly to distinguish platform-specific build directories and platform-specific built distributions. Typically includes the OS name and version and the architecture (as supplied by 'os.uname()'), although the exact information included depends on the OS; on Linux, the kernel version isn't particularly important. Examples of returned values: linux-i586 linux-alpha (?) solaris-2.6-sun4u Windows will return one of: win-amd64 (64bit Windows on AMD64 (aka x86_64, Intel64, EM64T, etc) win32 (all others - specifically, sys.platform is returned) For other non-POSIX platforms, currently just returns 'sys.platform'. """ if os.name == 'nt': if 'amd64' in sys.version.lower(): return 'win-amd64' return sys.platform if os.name != "posix" or not hasattr(os, 'uname'): # XXX what about the architecture? NT is Intel or Alpha return sys.platform # Set for cross builds explicitly if "_PYTHON_HOST_PLATFORM" in os.environ: return os.environ["_PYTHON_HOST_PLATFORM"] # Try to distinguish various flavours of Unix osname, host, release, version, machine = os.uname() # Convert the OS name to lowercase, remove '/' characters, and translate # spaces (for "Power Macintosh") osname = osname.lower().replace('/', '') machine = machine.replace(' ', '_') machine = machine.replace('/', '-') if osname[:5] == "linux": # At least on Linux/Intel, 'machine' is the processor -- # i386, etc. # XXX what about Alpha, SPARC, etc? return "%s-%s" % (osname, machine) elif osname[:5] == "sunos": if release[0] >= "5": # SunOS 5 == Solaris 2 osname = "solaris" release = "%d.%s" % (int(release[0]) - 3, release[2:]) # We can't use "platform.architecture()[0]" because a # bootstrap problem. We use a dict to get an error # if some suspicious happens. bitness = {2147483647:"32bit", 9223372036854775807:"64bit"} machine += ".%s" % bitness[sys.maxsize] # fall through to standard osname-release-machine representation elif osname[:3] == "aix": return "%s-%s.%s" % (osname, version, release) elif osname[:6] == "cygwin": osname = "cygwin" import re rel_re = re.compile(r'[\d.]+') m = rel_re.match(release) if m: release = m.group() elif osname[:6] == "darwin": import _osx_support osname, release, machine = _osx_support.get_platform_osx( get_config_vars(), osname, release, machine) return "%s-%s-%s" % (osname, release, machine) def get_python_version(): return _PY_VERSION_SHORT def _print_dict(title, data): for index, (key, value) in enumerate(sorted(data.items())): if index == 0: print('%s: ' % (title)) print('\t%s = "%s"' % (key, value)) def _main(): """Display all information sysconfig detains.""" if '--generate-posix-vars' in sys.argv: _generate_posix_vars() return print('Platform: "%s"' % get_platform()) print('Python version: "%s"' % get_python_version()) print('Current installation scheme: "%s"' % _get_default_scheme()) print() _print_dict('Paths', get_paths()) print() _print_dict('Variables', get_config_vars()) if __name__ == '__main__': _main()