https://github.com/patryk4815 created 
https://github.com/llvm/llvm-project/pull/123735

When the environment variables `_PYTHON_HOST_PLATFORM` and 
`_PYTHON_SYSCONFIGDATA_NAME` are set, the script 
`bindings/python/get-python-config.py` provides accurate data because the 
`sysconfig` module uses these variables internally. 

It is not well-documented in Python's official documentation and is only 
provided on a best-effort basis.
Some info here: [PEP 720 - Upstream 
Support](https://peps.python.org/pep-0720/#upstream-support).

Adding support for this environment variable in LLDB simplifies 
cross-compilation with Python, even though this functionality is not officially 
documented. Maintainers of various Linux distributions already use these 
environment variables, making it easier to build LLDB with Python support 
across different package distributions (eg: 
https://github.com/NixOS/nixpkgs/pull/375484 ).


>From 1883c703f335d44f5a4cfff8148c8d557ab6af1e Mon Sep 17 00:00:00 2001
From: Patryk Sondej <patryk.son...@grupawp.pl>
Date: Tue, 21 Jan 2025 12:44:44 +0100
Subject: [PATCH] Added support for `_PYTHON_HOST_PLATFORM` and
 `_PYTHON_SYSCONFIGDATA_NAME` environment variables when cross-compiling LLDB
 with Python, https://peps.python.org/pep-0720/#upstream-support

---
 lldb/CMakeLists.txt | 17 ++++++++++++++++-
 1 file changed, 16 insertions(+), 1 deletion(-)

diff --git a/lldb/CMakeLists.txt b/lldb/CMakeLists.txt
index 85ba4fde17418a..d11c68dd5b96af 100644
--- a/lldb/CMakeLists.txt
+++ b/lldb/CMakeLists.txt
@@ -59,8 +59,23 @@ if (LLDB_ENABLE_PYTHON)
   set(cachestring_LLDB_PYTHON_EXT_SUFFIX
     "Filename extension for native code python modules")
 
+  set(LLDB_USE_HOST_PYTHON FALSE)
+  if(NOT CMAKE_CROSSCOMPILING)
+    set(LLDB_USE_HOST_PYTHON TRUE)
+  else()
+    # Used when cross-compiling LLDB with Python:
+    # - `_PYTHON_HOST_PLATFORM`: Specifies the host platform, e.g., 
'linux-x86_64'.
+    # - `_PYTHON_SYSCONFIGDATA_NAME`: The name of the Python configuration 
module containing
+    #   platform, build, and configuration details (e.g., 
`_sysconfigdata__linux_x86_64-linux-gnu`).
+    # See: https://peps.python.org/pep-0720/#upstream-support
+    # If both environment variables are defined, we assume host Python can be 
used.
+    if(DEFINED ENV{_PYTHON_HOST_PLATFORM} AND DEFINED 
ENV{_PYTHON_SYSCONFIGDATA_NAME})
+      set(LLDB_USE_HOST_PYTHON TRUE)
+    endif()
+  endif()
+
   foreach(var LLDB_PYTHON_RELATIVE_PATH LLDB_PYTHON_EXE_RELATIVE_PATH 
LLDB_PYTHON_EXT_SUFFIX)
-    if(NOT DEFINED ${var} AND NOT CMAKE_CROSSCOMPILING)
+    if(NOT DEFINED ${var} AND LLDB_USE_HOST_PYTHON)
       execute_process(
         COMMAND ${Python3_EXECUTABLE}
           ${CMAKE_CURRENT_SOURCE_DIR}/bindings/python/get-python-config.py

_______________________________________________
lldb-commits mailing list
lldb-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-commits

Reply via email to