From: Gianfranco Costamagna Date: Wed, 18 Dec 2024 09:01:43 +0000 (+0100) Subject: print-lldb-path X-Git-Tag: archive/raspbian/1%19.1.7-1+rpi1^2^2~32 X-Git-Url: https://dgit.raspbian.org/?a=commitdiff_plain;h=b4371ed7768bbe760d6fb75f80db267d839e9fe1;p=llvm-toolchain-19.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 ae84cbb121..e702a3008c 100755 --- a/lldb/bindings/python/get-python-config.py +++ b/lldb/bindings/python/get-python-config.py @@ -16,6 +16,7 @@ def relpath_nodots(path, base): def main(): + import sysconfig parser = argparse.ArgumentParser(description="extract cmake variables from python") parser.add_argument("variable_name") args = parser.parse_args() @@ -32,7 +33,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 70fa6d83e3..e96a83694f 100644 --- a/lldb/source/Plugins/ScriptInterpreter/Python/ScriptInterpreterPython.cpp +++ b/lldb/source/Plugins/ScriptInterpreter/Python/ScriptInterpreterPython.cpp @@ -261,6 +261,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)