Skip to content
Projeler
Gruplar
Parçacıklar
Yardım
Yükleniyor...
Oturum aç / Kaydol
Gezinmeyi değiştir
C
cpython
Proje
Proje
Ayrıntılar
Etkinlik
Cycle Analytics
Depo (repository)
Depo (repository)
Dosyalar
Kayıtlar (commit)
Dallar (branch)
Etiketler
Katkıda bulunanlar
Grafik
Karşılaştır
Grafikler
Konular (issue)
0
Konular (issue)
0
Liste
Pano
Etiketler
Kilometre Taşları
Birleştirme (merge) Talepleri
0
Birleştirme (merge) Talepleri
0
CI / CD
CI / CD
İş akışları (pipeline)
İşler
Zamanlamalar
Grafikler
Paketler
Paketler
Wiki
Wiki
Parçacıklar
Parçacıklar
Üyeler
Üyeler
Collapse sidebar
Close sidebar
Etkinlik
Grafik
Grafikler
Yeni bir konu (issue) oluştur
İşler
Kayıtlar (commit)
Konu (issue) Panoları
Kenar çubuğunu aç
Batuhan Osman TASKAYA
cpython
Commits
469ee9d8
Kaydet (Commit)
469ee9d8
authored
Mar 22, 2013
tarafından
Benjamin Peterson
Dosyalara gözat
Seçenekler
Dosyalara Gözat
İndir
Eposta Yamaları
Sade Fark
backout 66e30c4870bb for breaking OSX (#13150)
üst
45072741
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
66 additions
and
93 deletions
+66
-93
sysconfig.py
Lib/distutils/sysconfig.py
+59
-4
pprint.py
Lib/pprint.py
+1
-4
sysconfig.py
Lib/sysconfig.py
+3
-72
Makefile.pre.in
Makefile.pre.in
+3
-9
NEWS
Misc/NEWS
+0
-4
No files found.
Lib/distutils/sysconfig.py
Dosyayı görüntüle @
469ee9d8
...
@@ -387,11 +387,66 @@ _config_vars = None
...
@@ -387,11 +387,66 @@ _config_vars = None
def
_init_posix
():
def
_init_posix
():
"""Initialize the module as appropriate for POSIX systems."""
"""Initialize the module as appropriate for POSIX systems."""
# _sysconfigdata is generated at build time, see the sysconfig module
g
=
{}
from
_sysconfigdata
import
build_time_vars
# load the installed Makefile:
try
:
filename
=
get_makefile_filename
()
parse_makefile
(
filename
,
g
)
except
IOError
,
msg
:
my_msg
=
"invalid Python installation: unable to open
%
s"
%
filename
if
hasattr
(
msg
,
"strerror"
):
my_msg
=
my_msg
+
" (
%
s)"
%
msg
.
strerror
raise
DistutilsPlatformError
(
my_msg
)
# load the installed pyconfig.h:
try
:
filename
=
get_config_h_filename
()
parse_config_h
(
file
(
filename
),
g
)
except
IOError
,
msg
:
my_msg
=
"invalid Python installation: unable to open
%
s"
%
filename
if
hasattr
(
msg
,
"strerror"
):
my_msg
=
my_msg
+
" (
%
s)"
%
msg
.
strerror
raise
DistutilsPlatformError
(
my_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
:
g
[
'LDSHARED'
]
=
g
[
'BLDSHARED'
]
elif
get_python_version
()
<
'2.1'
:
# The following two branches are for 1.5.2 compatibility.
if
sys
.
platform
==
'aix4'
:
# what about AIX 3.x ?
# Linker script is in the config directory, not in Modules as the
# Makefile says.
python_lib
=
get_python_lib
(
standard_lib
=
1
)
ld_so_aix
=
os
.
path
.
join
(
python_lib
,
'config'
,
'ld_so_aix'
)
python_exp
=
os
.
path
.
join
(
python_lib
,
'config'
,
'python.exp'
)
g
[
'LDSHARED'
]
=
"
%
s
%
s -bI:
%
s"
%
(
ld_so_aix
,
g
[
'CC'
],
python_exp
)
elif
sys
.
platform
==
'beos'
:
# Linker script is in the config directory. In the Makefile it is
# relative to the srcdir, which after installation no longer makes
# sense.
python_lib
=
get_python_lib
(
standard_lib
=
1
)
linkerscript_path
=
string
.
split
(
g
[
'LDSHARED'
])[
0
]
linkerscript_name
=
os
.
path
.
basename
(
linkerscript_path
)
linkerscript
=
os
.
path
.
join
(
python_lib
,
'config'
,
linkerscript_name
)
# XXX this isn't the right place to do this: adding the Python
# library to the link, if needed, should be in the "build_ext"
# command. (It's also needed for non-MS compilers on Windows, and
# it's taken care of for them by the 'build_ext.get_libraries()'
# method.)
g
[
'LDSHARED'
]
=
(
"
%
s -L
%
s/lib -lpython
%
s"
%
(
linkerscript
,
PREFIX
,
get_python_version
()))
global
_config_vars
global
_config_vars
_config_vars
=
{}
_config_vars
=
g
_config_vars
.
update
(
build_time_vars
)
def
_init_nt
():
def
_init_nt
():
...
...
Lib/pprint.py
Dosyayı görüntüle @
469ee9d8
...
@@ -37,10 +37,7 @@ saferepr()
...
@@ -37,10 +37,7 @@ saferepr()
import
sys
as
_sys
import
sys
as
_sys
import
warnings
import
warnings
try
:
from
cStringIO
import
StringIO
as
_StringIO
from
cStringIO
import
StringIO
as
_StringIO
except
ImportError
:
from
StringIO
import
StringIO
as
_StringIO
__all__
=
[
"pprint"
,
"pformat"
,
"isreadable"
,
"isrecursive"
,
"saferepr"
,
__all__
=
[
"pprint"
,
"pformat"
,
"isreadable"
,
"isrecursive"
,
"saferepr"
,
"PrettyPrinter"
]
"PrettyPrinter"
]
...
...
Lib/sysconfig.py
Dosyayı görüntüle @
469ee9d8
...
@@ -278,10 +278,9 @@ def _get_makefile_filename():
...
@@ -278,10 +278,9 @@ def _get_makefile_filename():
return
os
.
path
.
join
(
_PROJECT_BASE
,
"Makefile"
)
return
os
.
path
.
join
(
_PROJECT_BASE
,
"Makefile"
)
return
os
.
path
.
join
(
get_path
(
'platstdlib'
),
"config"
,
"Makefile"
)
return
os
.
path
.
join
(
get_path
(
'platstdlib'
),
"config"
,
"Makefile"
)
def
_generate_posix_vars
():
"""Generate the Python module containing build-time variables."""
def
_init_posix
(
vars
):
import
pprint
"""Initialize the module as appropriate for POSIX systems."""
vars
=
{}
# load the installed Makefile:
# load the installed Makefile:
makefile
=
_get_makefile_filename
()
makefile
=
_get_makefile_filename
()
try
:
try
:
...
@@ -309,49 +308,6 @@ def _generate_posix_vars():
...
@@ -309,49 +308,6 @@ def _generate_posix_vars():
if
_PYTHON_BUILD
:
if
_PYTHON_BUILD
:
vars
[
'LDSHARED'
]
=
vars
[
'BLDSHARED'
]
vars
[
'LDSHARED'
]
=
vars
[
'BLDSHARED'
]
# 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
=
'_sysconfigdata'
if
'darwin'
in
sys
.
platform
:
import
imp
module
=
imp
.
new_module
(
name
)
module
.
build_time_vars
=
vars
sys
.
modules
[
name
]
=
module
pybuilddir
=
'build/lib.
%
s-
%
s'
%
(
get_platform
(),
sys
.
version
[:
3
])
if
hasattr
(
sys
,
"gettotalrefcount"
):
pybuilddir
+=
'-pydebug'
try
:
os
.
makedirs
(
pybuilddir
)
except
OSError
:
pass
destfile
=
os
.
path
.
join
(
pybuilddir
,
name
+
'.py'
)
with
open
(
destfile
,
'wb'
)
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'
)
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()
from
_sysconfigdata
import
build_time_vars
vars
.
update
(
build_time_vars
)
def
_init_non_posix
(
vars
):
def
_init_non_posix
(
vars
):
"""Initialize the module as appropriate for NT"""
"""Initialize the module as appropriate for NT"""
# set basic install directories
# set basic install directories
...
@@ -609,28 +565,3 @@ def get_platform():
...
@@ -609,28 +565,3 @@ def get_platform():
def
get_python_version
():
def
get_python_version
():
return
_PY_VERSION_SHORT
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
()
Makefile.pre.in
Dosyayı görüntüle @
469ee9d8
...
@@ -437,20 +437,15 @@ $(BUILDPYTHON): Modules/python.o $(LIBRARY) $(LDLIBRARY)
...
@@ -437,20 +437,15 @@ $(BUILDPYTHON): Modules/python.o $(LIBRARY) $(LDLIBRARY)
Modules/python.o
\
Modules/python.o
\
$(BLDLIBRARY)
$(LIBS)
$(MODLIBS)
$(SYSLIBS)
$(LDLAST)
$(BLDLIBRARY)
$(LIBS)
$(MODLIBS)
$(SYSLIBS)
$(LDLAST)
platform
:
$(BUILDPYTHON)
pybuilddir.txt
platform
:
$(BUILDPYTHON)
$(RUNSHARED)
$(PYTHON_FOR_BUILD)
-c
'import sys ; from sysconfig import get_platform ; print get_platform()+"-"+sys.version[0:3]'
>
platform
$(RUNSHARED)
$(PYTHON_FOR_BUILD)
-c
'import sys ; from sysconfig import get_platform ; print get_platform()+"-"+sys.version[0:3]'
>
platform
# Create build directory and generate the sysconfig build-time data there.
# pybuilddir.txt contains the name of the build dir and is used for
# sys.path fixup -- see Modules/getpath.c.
pybuilddir.txt
:
$(BUILDPYTHON)
$(RUNSHARED)
$(PYTHON_FOR_BUILD)
-S
-m
sysconfig
--generate-posix-vars
# Build the shared modules
# Build the shared modules
# Under GNU make, MAKEFLAGS are sorted and normalized; the 's' for
# Under GNU make, MAKEFLAGS are sorted and normalized; the 's' for
# -s, --silent or --quiet is always the first char.
# -s, --silent or --quiet is always the first char.
# Under BSD make, MAKEFLAGS might be " -s -v x=y".
# Under BSD make, MAKEFLAGS might be " -s -v x=y".
sharedmods
:
$(BUILDPYTHON)
pybuilddir.txt
sharedmods
:
$(BUILDPYTHON)
@
case
"
$$
MAKEFLAGS"
in
\
@
case
"
$$
MAKEFLAGS"
in
\
*
\
-s
*
|
s
*
)
quiet
=
"-q"
;;
\
*
\
-s
*
|
s
*
)
quiet
=
"-q"
;;
\
*
)
quiet
=
""
;;
\
*
)
quiet
=
""
;;
\
...
@@ -960,7 +955,7 @@ libinstall: build_all $(srcdir)/Lib/$(PLATDIR) $(srcdir)/Modules/xxmodule.c
...
@@ -960,7 +955,7 @@ libinstall: build_all $(srcdir)/Lib/$(PLATDIR) $(srcdir)/Modules/xxmodule.c
else
true
;
\
else
true
;
\
fi
;
\
fi
;
\
done
done
@
for
i
in
$(srcdir)
/Lib/
*
.py
`
cat
pybuilddir.txt
`
/_sysconfigdata.py
$(srcdir)
/Lib/
*
.doc
$(srcdir)
/Lib/
*
.egg-info
;
\
@
for
i
in
$(srcdir)
/Lib/
*
.py
$(srcdir)
/Lib/
*
.doc
$(srcdir)
/Lib/
*
.egg-info
;
\
do
\
do
\
if
test
-x
$$
i
;
then
\
if
test
-x
$$
i
;
then
\
$(INSTALL_SCRIPT)
$$
i
$(DESTDIR)$(LIBDEST)
;
\
$(INSTALL_SCRIPT)
$$
i
$(DESTDIR)$(LIBDEST)
;
\
...
@@ -1138,7 +1133,6 @@ sharedinstall: sharedmods
...
@@ -1138,7 +1133,6 @@ sharedinstall: sharedmods
--install-scripts
=
$(BINDIR)
\
--install-scripts
=
$(BINDIR)
\
--install-platlib
=
$(DESTSHARED)
\
--install-platlib
=
$(DESTSHARED)
\
--root
=
$(DESTDIR)
/
--root
=
$(DESTDIR)
/
-
rm
$(DESTDIR)$(DESTSHARED)
/_sysconfigdata.py
*
# Here are a couple of targets for MacOSX again, to install a full
# Here are a couple of targets for MacOSX again, to install a full
# framework-based Python. frameworkinstall installs everything, the
# framework-based Python. frameworkinstall installs everything, the
...
...
Misc/NEWS
Dosyayı görüntüle @
469ee9d8
...
@@ -216,10 +216,6 @@ Core and Builtins
...
@@ -216,10 +216,6 @@ Core and Builtins
Library
Library
-------
-------
- Issue #13150: sysconfig no longer parses the Makefile and config.h files
when imported, instead doing it at build time. This makes importing
sysconfig faster and reduces Python startup time by 20%.
- Issue #10212: cStringIO and struct.unpack support new buffer objects.
- Issue #10212: cStringIO and struct.unpack support new buffer objects.
- Issue #12098: multiprocessing on Windows now starts child processes
- Issue #12098: multiprocessing on Windows now starts child processes
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment