From: Gianfranco Costamagna Date: Sat, 4 May 2024 05:27:41 +0000 (+0200) Subject: print-lldb-path X-Git-Tag: archive/raspbian/1%16.0.6-27+rpi1~1^2~31 X-Git-Url: https://dgit.raspbian.org/?a=commitdiff_plain;h=b61e1739ef26eb70a6a96e6c7a86c3de63e22e08;p=llvm-toolchain-16.git print-lldb-path Last-Update: 2023-01-19 Gbp-Pq: Topic lldb Gbp-Pq: Name print-lldb-path.patch --- diff --git a/lldb/bindings/python/get-python-config.py b/lldb/bindings/python/get-python-config.py index 6369e32a49..3871873d99 100755 --- a/lldb/bindings/python/get-python-config.py +++ b/lldb/bindings/python/get-python-config.py @@ -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 diff --git a/lldb/source/Plugins/ScriptInterpreter/Python/ScriptInterpreterPython.cpp b/lldb/source/Plugins/ScriptInterpreter/Python/ScriptInterpreterPython.cpp index 7026815e12..19b8b131b0 100644 --- a/lldb/source/Plugins/ScriptInterpreter/Python/ScriptInterpreterPython.cpp +++ b/lldb/source/Plugins/ScriptInterpreter/Python/ScriptInterpreterPython.cpp @@ -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)