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
bf430cde
Kaydet (Commit)
bf430cde
authored
Haz 29, 2011
tarafından
Ned Deily
Dosyalara gözat
Seçenekler
Dosyalara Gözat
İndir
Sade Fark
Merge default.
üst
4f86193a
044369fd
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
191 additions
and
27 deletions
+191
-27
spawn.py
Lib/distutils/spawn.py
+28
-1
sysconfig.py
Lib/distutils/sysconfig.py
+0
-15
test_build_ext.py
Lib/distutils/tests/test_build_ext.py
+37
-10
test_command_build_ext.py
Lib/packaging/tests/test_command_build_ext.py
+92
-1
util.py
Lib/packaging/util.py
+23
-0
NEWS
Misc/NEWS
+11
-0
No files found.
Lib/distutils/spawn.py
Dosyayı görüntüle @
bf430cde
...
...
@@ -96,15 +96,42 @@ def _spawn_os2(cmd, search_path=1, verbose=0, dry_run=0):
raise
DistutilsExecError
(
"command '
%
s' failed with exit status
%
d"
%
(
cmd
[
0
],
rc
))
if
sys
.
platform
==
'darwin'
:
from
distutils
import
sysconfig
_cfg_target
=
None
_cfg_target_split
=
None
def
_spawn_posix
(
cmd
,
search_path
=
1
,
verbose
=
0
,
dry_run
=
0
):
log
.
info
(
' '
.
join
(
cmd
))
if
dry_run
:
return
exec_fn
=
search_path
and
os
.
execvp
or
os
.
execv
exec_args
=
[
cmd
[
0
],
cmd
]
if
sys
.
platform
==
'darwin'
:
global
_cfg_target
,
_cfg_target_split
if
_cfg_target
is
None
:
_cfg_target
=
sysconfig
.
get_config_var
(
'MACOSX_DEPLOYMENT_TARGET'
)
or
''
if
_cfg_target
:
_cfg_target_split
=
[
int
(
x
)
for
x
in
_cfg_target
.
split
(
'.'
)]
if
_cfg_target
:
# ensure that the deployment target of build process is not less
# than that used when the interpreter was built. This ensures
# extension modules are built with correct compatibility values
cur_target
=
os
.
environ
.
get
(
'MACOSX_DEPLOYMENT_TARGET'
,
_cfg_target
)
if
_cfg_target_split
>
[
int
(
x
)
for
x
in
cur_target
.
split
(
'.'
)]:
my_msg
=
(
'$MACOSX_DEPLOYMENT_TARGET mismatch: '
'now "
%
s" but "
%
s" during configure'
%
(
cur_target
,
_cfg_target
))
raise
DistutilsPlatformError
(
my_msg
)
env
=
dict
(
os
.
environ
,
MACOSX_DEPLOYMENT_TARGET
=
cur_target
)
exec_fn
=
search_path
and
os
.
execvpe
or
os
.
execve
exec_args
.
append
(
env
)
pid
=
os
.
fork
()
if
pid
==
0
:
# in the child
try
:
exec_fn
(
cmd
[
0
],
cmd
)
exec_fn
(
*
exec_args
)
except
OSError
as
e
:
sys
.
stderr
.
write
(
"unable to execute
%
s:
%
s
\n
"
%
(
cmd
[
0
],
e
.
strerror
))
...
...
Lib/distutils/sysconfig.py
Dosyayı görüntüle @
bf430cde
...
...
@@ -419,21 +419,6 @@ def _init_posix():
raise
DistutilsPlatformError
(
my_msg
)
# On MacOSX we need to check the setting of the environment variable
# MACOSX_DEPLOYMENT_TARGET: configure bases some choices on it so
# it needs to be compatible.
# If it isn't set we set it to the configure-time value
if
sys
.
platform
==
'darwin'
and
'MACOSX_DEPLOYMENT_TARGET'
in
g
:
cfg_target
=
g
[
'MACOSX_DEPLOYMENT_TARGET'
]
cur_target
=
os
.
getenv
(
'MACOSX_DEPLOYMENT_TARGET'
,
''
)
if
cur_target
==
''
:
cur_target
=
cfg_target
os
.
environ
[
'MACOSX_DEPLOYMENT_TARGET'
]
=
cfg_target
elif
[
int
(
x
)
for
x
in
cfg_target
.
split
(
'.'
)]
>
[
int
(
x
)
for
x
in
cur_target
.
split
(
'.'
)]:
my_msg
=
(
'$MACOSX_DEPLOYMENT_TARGET mismatch: now "
%
s" but "
%
s" during configure'
%
(
cur_target
,
cfg_target
))
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.
...
...
Lib/distutils/tests/test_build_ext.py
Dosyayı görüntüle @
bf430cde
...
...
@@ -11,7 +11,8 @@ from distutils.tests.support import TempdirManager
from
distutils.tests.support
import
LoggingSilencer
from
distutils.extension
import
Extension
from
distutils.errors
import
(
CompileError
,
DistutilsSetupError
,
UnknownFileError
)
CompileError
,
DistutilsPlatformError
,
DistutilsSetupError
,
UnknownFileError
)
import
unittest
from
test
import
support
...
...
@@ -431,18 +432,43 @@ class BuildExtTestCase(TempdirManager,
@unittest.skipUnless
(
sys
.
platform
==
'darwin'
,
'test only relevant for MacOSX'
)
def
test_deployment_target
(
self
):
self
.
_try_compile_deployment_target
()
def
test_deployment_target_default
(
self
):
# Issue 9516: Test that, in the absence of the environment variable,
# an extension module is compiled with the same deployment target as
# the interpreter.
self
.
_try_compile_deployment_target
(
'=='
,
None
)
@unittest.skipUnless
(
sys
.
platform
==
'darwin'
,
'test only relevant for MacOSX'
)
def
test_deployment_target_too_low
(
self
):
# Issue 9516: Test that an extension module is not allowed to be
# compiled with a deployment target less than that of the interpreter.
self
.
assertRaises
(
DistutilsPlatformError
,
self
.
_try_compile_deployment_target
,
'>'
,
'10.1'
)
@unittest.skipUnless
(
sys
.
platform
==
'darwin'
,
'test only relevant for MacOSX'
)
def
test_deployment_target_higher_ok
(
self
):
# Issue 9516: Test that an extension module can be compiled with a
# deployment target higher than that of the interpreter: the ext
# module may depend on some newer OS feature.
deptarget
=
sysconfig
.
get_config_var
(
'MACOSX_DEPLOYMENT_TARGET'
)
if
deptarget
:
# increment the minor version number (i.e. 10.6 -> 10.7)
deptarget
=
[
int
(
x
)
for
x
in
deptarget
.
split
(
'.'
)]
deptarget
[
-
1
]
+=
1
deptarget
=
'.'
.
join
(
str
(
i
)
for
i
in
deptarget
)
self
.
_try_compile_deployment_target
(
'<'
,
deptarget
)
def
_try_compile_deployment_target
(
self
,
operator
,
target
):
orig_environ
=
os
.
environ
os
.
environ
=
orig_environ
.
copy
()
self
.
addCleanup
(
setattr
,
os
,
'environ'
,
orig_environ
)
os
.
environ
[
'MACOSX_DEPLOYMENT_TARGET'
]
=
'10.1'
self
.
_try_compile_deployment_target
()
if
target
is
None
:
if
os
.
environ
.
get
(
'MACOSX_DEPLOYMENT_TARGET'
):
del
os
.
environ
[
'MACOSX_DEPLOYMENT_TARGET'
]
else
:
os
.
environ
[
'MACOSX_DEPLOYMENT_TARGET'
]
=
target
def
_try_compile_deployment_target
(
self
):
deptarget_c
=
os
.
path
.
join
(
self
.
tmp_dir
,
'deptargetmodule.c'
)
with
open
(
deptarget_c
,
'w'
)
as
fp
:
...
...
@@ -451,16 +477,17 @@ class BuildExtTestCase(TempdirManager,
int dummy;
#if TARGET != MAC_OS_X_VERSION_MIN_REQUIRED
#if TARGET
%
s MAC_OS_X_VERSION_MIN_REQUIRED
#else
#error "Unexpected target"
#endif
'''
))
'''
%
operator
))
# get the deployment target that the interpreter was built with
target
=
sysconfig
.
get_config_var
(
'MACOSX_DEPLOYMENT_TARGET'
)
target
=
tuple
(
map
(
int
,
target
.
split
(
'.'
)))
target
=
'
%02
d
%01
d0'
%
target
deptarget_ext
=
Extension
(
'deptarget'
,
[
deptarget_c
],
...
...
Lib/packaging/tests/test_command_build_ext.py
Dosyayı görüntüle @
bf430cde
...
...
@@ -3,9 +3,11 @@ import sys
import
site
import
shutil
import
sysconfig
import
textwrap
from
io
import
StringIO
from
packaging.dist
import
Distribution
from
packaging.errors
import
UnknownFileError
,
CompileError
from
packaging.errors
import
(
UnknownFileError
,
CompileError
,
PackagingPlatformError
)
from
packaging.command.build_ext
import
build_ext
from
packaging.compiler.extension
import
Extension
from
test.script_helper
import
assert_python_ok
...
...
@@ -362,6 +364,95 @@ class BuildExtTestCase(support.TempdirManager,
wanted
=
os
.
path
.
join
(
curdir
,
'twisted'
,
'runner'
,
'portmap'
+
ext
)
self
.
assertEqual
(
wanted
,
path
)
@unittest.skipUnless
(
sys
.
platform
==
'darwin'
,
'test only relevant for Mac OS X'
)
def
test_deployment_target_default
(
self
):
# Issue 9516: Test that, in the absence of the environment variable,
# an extension module is compiled with the same deployment target as
# the interpreter.
self
.
_try_compile_deployment_target
(
'=='
,
None
)
@unittest.skipUnless
(
sys
.
platform
==
'darwin'
,
'test only relevant for Mac OS X'
)
def
test_deployment_target_too_low
(
self
):
# Issue 9516: Test that an extension module is not allowed to be
# compiled with a deployment target less than that of the interpreter.
self
.
assertRaises
(
PackagingPlatformError
,
self
.
_try_compile_deployment_target
,
'>'
,
'10.1'
)
@unittest.skipUnless
(
sys
.
platform
==
'darwin'
,
'test only relevant for Mac OS X'
)
def
test_deployment_target_higher_ok
(
self
):
# Issue 9516: Test that an extension module can be compiled with a
# deployment target higher than that of the interpreter: the ext
# module may depend on some newer OS feature.
deptarget
=
sysconfig
.
get_config_var
(
'MACOSX_DEPLOYMENT_TARGET'
)
if
deptarget
:
# increment the minor version number (i.e. 10.6 -> 10.7)
deptarget
=
[
int
(
x
)
for
x
in
deptarget
.
split
(
'.'
)]
deptarget
[
-
1
]
+=
1
deptarget
=
'.'
.
join
(
str
(
i
)
for
i
in
deptarget
)
self
.
_try_compile_deployment_target
(
'<'
,
deptarget
)
def
_try_compile_deployment_target
(
self
,
operator
,
target
):
orig_environ
=
os
.
environ
os
.
environ
=
orig_environ
.
copy
()
self
.
addCleanup
(
setattr
,
os
,
'environ'
,
orig_environ
)
if
target
is
None
:
if
os
.
environ
.
get
(
'MACOSX_DEPLOYMENT_TARGET'
):
del
os
.
environ
[
'MACOSX_DEPLOYMENT_TARGET'
]
else
:
os
.
environ
[
'MACOSX_DEPLOYMENT_TARGET'
]
=
target
deptarget_c
=
os
.
path
.
join
(
self
.
tmp_dir
,
'deptargetmodule.c'
)
with
open
(
deptarget_c
,
'w'
)
as
fp
:
fp
.
write
(
textwrap
.
dedent
(
'''
\
#include <AvailabilityMacros.h>
int dummy;
#if TARGET
%
s MAC_OS_X_VERSION_MIN_REQUIRED
#else
#error "Unexpected target"
#endif
'''
%
operator
))
# get the deployment target that the interpreter was built with
target
=
sysconfig
.
get_config_var
(
'MACOSX_DEPLOYMENT_TARGET'
)
target
=
tuple
(
map
(
int
,
target
.
split
(
'.'
)))
target
=
'
%02
d
%01
d0'
%
target
deptarget_ext
=
Extension
(
'deptarget'
,
[
deptarget_c
],
extra_compile_args
=
[
'-DTARGET=
%
s'
%
(
target
,)],
)
dist
=
Distribution
({
'name'
:
'deptarget'
,
'ext_modules'
:
[
deptarget_ext
],
})
dist
.
package_dir
=
self
.
tmp_dir
cmd
=
build_ext
(
dist
)
cmd
.
build_lib
=
self
.
tmp_dir
cmd
.
build_temp
=
self
.
tmp_dir
try
:
old_stdout
=
sys
.
stdout
if
not
verbose
:
# silence compiler output
sys
.
stdout
=
StringIO
()
try
:
cmd
.
ensure_finalized
()
cmd
.
run
()
finally
:
sys
.
stdout
=
old_stdout
except
CompileError
:
self
.
fail
(
"Wrong deployment target during compilation"
)
def
test_suite
():
src
=
_get_source_filename
()
...
...
Lib/packaging/util.py
Dosyayı görüntüle @
bf430cde
...
...
@@ -757,6 +757,9 @@ def split_leading_dir(path):
else
:
return
path
,
''
if
sys
.
platform
==
'darwin'
:
_cfg_target
=
None
_cfg_target_split
=
None
def
spawn
(
cmd
,
search_path
=
True
,
verbose
=
0
,
dry_run
=
False
,
env
=
None
):
"""Run another program specified as a command list 'cmd' in a new process.
...
...
@@ -781,6 +784,26 @@ def spawn(cmd, search_path=True, verbose=0, dry_run=False, env=None):
if
dry_run
:
logging
.
debug
(
'dry run, no process actually spawned'
)
return
if
sys
.
platform
==
'darwin'
:
global
_cfg_target
,
_cfg_target_split
if
_cfg_target
is
None
:
_cfg_target
=
sysconfig
.
get_config_var
(
'MACOSX_DEPLOYMENT_TARGET'
)
or
''
if
_cfg_target
:
_cfg_target_split
=
[
int
(
x
)
for
x
in
_cfg_target
.
split
(
'.'
)]
if
_cfg_target
:
# ensure that the deployment target of build process is not less
# than that used when the interpreter was built. This ensures
# extension modules are built with correct compatibility values
env
=
env
or
os
.
environ
cur_target
=
env
.
get
(
'MACOSX_DEPLOYMENT_TARGET'
,
_cfg_target
)
if
_cfg_target_split
>
[
int
(
x
)
for
x
in
cur_target
.
split
(
'.'
)]:
my_msg
=
(
'$MACOSX_DEPLOYMENT_TARGET mismatch: '
'now "
%
s" but "
%
s" during configure'
%
(
cur_target
,
_cfg_target
))
raise
PackagingPlatformError
(
my_msg
)
env
=
dict
(
env
,
MACOSX_DEPLOYMENT_TARGET
=
cur_target
)
exit_status
=
subprocess
.
call
(
cmd
,
env
=
env
)
if
exit_status
!=
0
:
msg
=
"command
%
r failed with exit status
%
d"
...
...
Misc/NEWS
Dosyayı görüntüle @
bf430cde
...
...
@@ -200,6 +200,17 @@ Core and Builtins
Library
-------
- Issue #9516: On Mac OS X, change Distutils to no longer globally attempt to
check or set the MACOSX_DEPLOYMENT_TARGET environment variable for the
interpreter process. This could cause failures in non-Distutils subprocesses
and was unreliable since tests or user programs could modify the interpreter
environment after Distutils set it. Instead, have Distutils set the the
deployment target only in the environment of each build subprocess. It is
still possible to globally override the default by setting
MACOSX_DEPLOYMENT_TARGET before launching the interpreter; its value must be
greater or equal to the default value, the value with which the interpreter
was built. Also, implement the same handling in packaging.
- Issue #12422: In the copy module, don'
t
store
objects
that
are
their
own
copy
in
the
memo
dict
.
...
...
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