From 4045392e0e3446362841b3336497cb6eeccfcd23 Mon Sep 17 00:00:00 2001 From: Christian Heimes Date: Sat, 4 Dec 2021 12:21:43 +0200 Subject: bpo-45847: Port _ctypes partly to PY_STDLIB_MOD (GH-29747) Co-authored-by: Erlend Egeberg Aasland --- setup.py | 59 ++++++++++++++++++++++++++--------------------------------- 1 file changed, 26 insertions(+), 33 deletions(-) (limited to 'setup.py') diff --git a/setup.py b/setup.py index 572f2ac1783..ca5d0774e00 100644 --- a/setup.py +++ b/setup.py @@ -669,12 +669,6 @@ def print_three_column(lst): raise RuntimeError("Failed to build some stdlib modules") def build_extension(self, ext): - - if ext.name == '_ctypes': - if not self.configure_ctypes(ext): - self.failed.append(ext.name) - return - try: build_ext.build_extension(self, ext) except (CCompilerError, DistutilsError) as why: @@ -1738,10 +1732,26 @@ def detect_tkinter(self): library_dirs=added_lib_dirs)) return True - def configure_ctypes(self, ext): - return True - def detect_ctypes(self): + ext = Extension( + '_ctypes', + [ + '_ctypes/_ctypes.c', + '_ctypes/callbacks.c', + '_ctypes/callproc.c', + '_ctypes/stgdict.c', + '_ctypes/cfield.c', + ] + ) + if MACOS: + self._build_ctypes_macos(ext) + else: + self.use_system_libffi = True + self.addext(ext) + + self.addext(Extension('_ctypes_test', ['_ctypes/_ctypes_test.c'])) + + def _build_ctypes_macos(self, ext): # Thomas Heller's _ctypes module if (not sysconfig.get_config_var("LIBFFI_INCLUDEDIR") and MACOS): @@ -1749,20 +1759,11 @@ def detect_ctypes(self): else: self.use_system_libffi = '--with-system-ffi' in sysconfig.get_config_var("CONFIG_ARGS") - include_dirs = [] - extra_compile_args = [] - extra_link_args = [] - sources = ['_ctypes/_ctypes.c', - '_ctypes/callbacks.c', - '_ctypes/callproc.c', - '_ctypes/stgdict.c', - '_ctypes/cfield.c'] - if MACOS: - sources.append('_ctypes/malloc_closure.c') - extra_compile_args.append('-DUSING_MALLOC_CLOSURE_DOT_C=1') - extra_compile_args.append('-DMACOSX') - include_dirs.append('_ctypes/darwin') + ext.sources.append('_ctypes/malloc_closure.c') + ext.extra_compile_args.append('-DUSING_MALLOC_CLOSURE_DOT_C=1') + ext.extra_compile_args.append('-DMACOSX') + ext.include_dirs.append('_ctypes/darwin') elif HOST_PLATFORM == 'sunos5': # XXX This shouldn't be necessary; it appears that some @@ -1773,20 +1774,12 @@ def detect_ctypes(self): # this option. If you want to compile ctypes with the Sun # compiler, please research a proper solution, instead of # finding some -z option for the Sun compiler. - extra_link_args.append('-mimpure-text') + ext.extra_link_args.append('-mimpure-text') elif HOST_PLATFORM.startswith('hp-ux'): - extra_link_args.append('-fPIC') - - ext = Extension('_ctypes', - include_dirs=include_dirs, - extra_compile_args=extra_compile_args, - extra_link_args=extra_link_args, - libraries=[], - sources=sources) + ext.extra_link_args.append('-fPIC') + self.add(ext) - # function my_sqrt() needs libm for sqrt() - self.addext(Extension('_ctypes_test', ['_ctypes/_ctypes_test.c'])) ffi_inc = sysconfig.get_config_var("LIBFFI_INCLUDEDIR") ffi_lib = None -- cgit v1.2.3-65-gdbad