diff options
author | Jason R. Coombs <jaraco@jaraco.com> | 2020-09-01 21:28:56 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-09-01 21:28:56 -0400 |
commit | 526b7fe0cf4e6c96176ffd6eaf286b758239ed45 (patch) | |
tree | 4487e9297d8b018fc49b120e2a9d26cd750e6958 | |
parent | 5ab258b9a3609ebe3fbe7b4fca600b3f36e4de32 (diff) | |
parent | 97a8f11a8a039fc0de04a31d281715f1ce6ea4bc (diff) | |
download | python-setuptools-git-526b7fe0cf4e6c96176ffd6eaf286b758239ed45.tar.gz |
Merge pull request #10 from pypa/bugfix/9-legacy-link-libpython
Restore pythonlib support on older Pythons.
-rw-r--r-- | distutils/command/build_ext.py | 3 | ||||
-rw-r--r-- | distutils/command/py37compat.py | 30 |
2 files changed, 32 insertions, 1 deletions
diff --git a/distutils/command/build_ext.py b/distutils/command/build_ext.py index 1a9bd120..bbb34833 100644 --- a/distutils/command/build_ext.py +++ b/distutils/command/build_ext.py @@ -16,6 +16,7 @@ from distutils.dep_util import newer_group from distutils.extension import Extension from distutils.util import get_platform from distutils import log +from . import py37compat from site import USER_BASE @@ -751,4 +752,4 @@ class build_ext(Command): ldversion = get_config_var('LDVERSION') return ext.libraries + ['python' + ldversion] - return ext.libraries + return ext.libraries + py37compat.pythonlib() diff --git a/distutils/command/py37compat.py b/distutils/command/py37compat.py new file mode 100644 index 00000000..754715a5 --- /dev/null +++ b/distutils/command/py37compat.py @@ -0,0 +1,30 @@ +import sys + + +def _pythonlib_compat(): + """ + On Python 3.7 and earlier, distutils would include the Python + library. See pypa/distutils#9. + """ + from distutils import sysconfig + if not sysconfig.get_config_var('Py_ENABLED_SHARED'): + return + + yield 'python{}.{}{}'.format( + sys.hexversion >> 24, + (sys.hexversion >> 16) & 0xff, + sysconfig.get_config_var('ABIFLAGS'), + ) + + +def compose(f1, f2): + return lambda *args, **kwargs: f1(f2(*args, **kwargs)) + + +pythonlib = ( + compose(list, _pythonlib_compat) + if sys.version_info < (3, 8) + and sys.platform != 'darwin' + and sys.platform[:3] != 'aix' + else list +) |