Fix typos
[babeltrace.git] / src / bindings / python / bt2 / setup.py.in
index 9b4294c7e0c9712cea32350342f14fa4744b44eb..cadefb728b10569ffc1297d85027a582324cc9a3 100644 (file)
@@ -6,13 +6,37 @@
 import sys
 import os
 
-if sys.version_info < (3, 12):
-    from distutils.core import setup, Extension
-    import distutils.sysconfig as sysconfig
-else:
+# Distutils was removed in Python 3.12, use setuptools as an alternative.
+if sys.version_info >= (3, 12):
     from setuptools import setup, Extension
+else:
+    from distutils.core import setup, Extension
+
+# Starting with Debian's Python 3.10, the default install scheme is
+# 'posix_local' which is a Debian specific scheme based on 'posix_prefix' but
+# with an added 'local' prefix. This is the default so users doing system wide
+# manual installations of python modules end up in '/usr/local'. This
+# interferes with our autotools based install which already defaults to
+# '/usr/local' and expect a provided prefix to be used verbatim.
+#
+# Monkeypatch sysconfig to override this scheme and use 'posix_prefix' instead.
+if sys.version_info >= (3, 10):
     import sysconfig
 
+    original_get_preferred_scheme = sysconfig.get_preferred_scheme
+
+    def our_get_preferred_scheme(key):
+        scheme = original_get_preferred_scheme(key)
+        if scheme == "posix_local":
+            return "posix_prefix"
+        else:
+            return scheme
+
+    sysconfig.get_preferred_scheme = our_get_preferred_scheme
+
+else:
+    import distutils.sysconfig as sysconfig
+
 PY_PATH_WARN_MSG = """
 -------------------------------------WARNING------------------------------------
 The install directory used:\n ({})\nis not included in your PYTHONPATH.
@@ -36,12 +60,12 @@ def get_cflags():
 
 
 # distutils performs a similar transformation step on LDSHARED on
-# darwin to use the overriden CC as the default command for LDSHARED
+# darwin to use the overridden CC as the default command for LDSHARED
 # (see distutils' customize_compiler() step in the sysconfig module).
 #
 # This takes it a step further by using our own LDFLAGS (when available)
-# along with the overriden compiler and ensure that flags that are unsupported
-# by either the Python interprter's CC or the overriden CC don't cause a
+# along with the overridden compiler and ensure that flags that are unsupported
+# by either the Python interprter's CC or the overridden CC don't cause a
 # build failure.
 def get_ldshared():
     cc = os.environ.get("CC")
@@ -95,11 +119,11 @@ def main():
         sources=["bt2/native_bt.c", "@srcdir@/bt2/logging.c"],
         libraries=["babeltrace2", "glib-2.0"],
         extra_objects=[
-            "@top_builddir@/src/autodisc/.libs/libbabeltrace2-autodisc.a",
-            "@top_builddir@/src/logging/.libs/libbabeltrace2-logging.a",
-            "@top_builddir@/src/common/.libs/libbabeltrace2-common.a",
-            "@top_builddir@/src/py-common/.libs/libbabeltrace2-py-common.a",
-            "@top_builddir@/src/string-format/.libs/libbabeltrace2-string-format.a",
+            "@top_builddir@/src/autodisc/.libs/libautodisc.a",
+            "@top_builddir@/src/logging/.libs/liblogging.a",
+            "@top_builddir@/src/common/.libs/libcommon.a",
+            "@top_builddir@/src/py-common/.libs/libpy-common.a",
+            "@top_builddir@/src/string-format/.libs/libstring-format.a",
         ],
     )
 
This page took 0.028765 seconds and 4 git commands to generate.