print-lldb-path
authorGianfranco Costamagna <locutusofborg@debian.org>
Mon, 11 Sep 2023 13:40:42 +0000 (14:40 +0100)
committerGianfranco Costamagna <locutusofborg@debian.org>
Mon, 11 Sep 2023 13:40:42 +0000 (14:40 +0100)
Last-Update: 2023-01-19

Gbp-Pq: Topic lldb
Gbp-Pq: Name print-lldb-path.patch

lldb/bindings/python/get-python-config.py
lldb/source/Plugins/ScriptInterpreter/Python/ScriptInterpreterPython.cpp

index 6369e32a49168c724785dc9f20730a16c459f001..3871873d99b44aa962b1b02ff9d135faec092885 100755 (executable)
@@ -15,6 +15,7 @@ def relpath_nodots(path, base):
     return rel
 
 def main():
+    import sysconfig
     parser = argparse.ArgumentParser(description="extract cmake variables from python")
     parser.add_argument("variable_name")
     args = parser.parse_args()
@@ -31,7 +32,19 @@ def main():
         # If not, you'll have to use lldb -P or lldb -print-script-interpreter-info
         # to figure out where it is.
         try:
-            print(relpath_nodots(sysconfig.get_path("platlib"), sys.prefix))
+            if hasattr(sysconfig, 'get_default_scheme'):
+                scheme = sysconfig.get_default_scheme()
+            else:
+                scheme = sysconfig._get_default_scheme()
+            if scheme == 'posix_local':
+                # Debian's default scheme installs to /usr/local/ but we want to find headers in /usr/
+                scheme = 'posix_prefix'
+                path = sysconfig.get_path('purelib', scheme)
+            else:
+                from distutils import sysconfig
+                path = sysconfig.get_python_lib(0, 0)
+
+            print(relpath_nodots(path, sys.prefix))
         except ValueError:
             # Try to fall back to something reasonable if sysconfig's platlib
             # is outside of sys.prefix
index 7026815e120d2907d27b5df6585a7477948296bc..19b8b131b0c3e3a3183c3931ac79e3f9a6250fcf 100644 (file)
@@ -240,6 +240,7 @@ void ScriptInterpreterPython::ComputePythonDir(
   // the real python interpreter uses.  (e.g. lib for most, lib64 on RHEL
   // x86_64, or bin on Windows).
   llvm::sys::path::remove_filename(path);
+  llvm::sys::path::append(path, "/llvm-" + std::to_string(LLVM_VERSION_MAJOR));
   llvm::sys::path::append(path, LLDB_PYTHON_RELATIVE_LIBDIR);
 
 #if defined(_WIN32)