From f4360f0a895d317d2011254397e3a37bb10e6311 Mon Sep 17 00:00:00 2001 From: Jan Tattermusch Date: Tue, 9 Feb 2021 17:56:44 +0100 Subject: [PATCH] reintroduce setup.py changes from #8280 erased by piper import #8617 --- python/setup.py | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) diff --git a/python/setup.py b/python/setup.py index aab240a0e55a..696bde2aedf3 100755 --- a/python/setup.py +++ b/python/setup.py @@ -18,6 +18,7 @@ from distutils.command.build_py import build_py as _build_py from distutils.command.clean import clean as _clean +from distutils.command.build_ext import build_ext as _build_ext from distutils.spawn import find_executable # Find the Protocol Compiler. @@ -157,6 +158,22 @@ def find_package_modules(self, package, package_dir): if not any(fnmatch.fnmatchcase(fil, pat=pat) for pat in exclude)] +class build_ext(_build_ext): + def get_ext_filename(self, ext_name): + # since python3.5, python extensions' shared libraries use a suffix that corresponds to the value + # of sysconfig.get_config_var('EXT_SUFFIX') and contains info about the architecture the library targets. + # E.g. on x64 linux the suffix is ".cpython-XYZ-x86_64-linux-gnu.so" + # When crosscompiling python wheels, we need to be able to override this suffix + # so that the resulting file name matches the target architecture and we end up with a well-formed + # wheel. + filename = _build_ext.get_ext_filename(self, ext_name) + orig_ext_suffix = sysconfig.get_config_var("EXT_SUFFIX") + new_ext_suffix = os.getenv("PROTOCOL_BUFFERS_OVERRIDE_EXT_SUFFIX") + if new_ext_suffix and filename.endswith(orig_ext_suffix): + filename = filename[:-len(orig_ext_suffix)] + new_ext_suffix + return filename + + class test_conformance(_build_py): target = 'test_python' def run(self): @@ -291,6 +308,7 @@ def get_option_from_sys_argv(option_str): cmdclass={ 'clean': clean, 'build_py': build_py, + 'build_ext': build_ext, 'test_conformance': test_conformance, }, install_requires=install_requires,