aboutsummaryrefslogtreecommitdiff
path: root/mesonbuild/scripts
diff options
context:
space:
mode:
authorRalf Gommers <ralf.gommers@gmail.com>2024-05-27 22:55:39 +0200
committerJussi Pakkanen <jpakkane@gmail.com>2024-06-23 13:23:31 +0300
commita111c28ecef721af960721c26b40f4e5108760c7 (patch)
treec6bbe61d3e0e5e8e4061d58bc5f8ae22d19e208a /mesonbuild/scripts
parentc0ca35c8fd796bea4bd92f88b03cb3d6abd2096c (diff)
downloadmeson-a111c28ecef721af960721c26b40f4e5108760c7.zip
meson-a111c28ecef721af960721c26b40f4e5108760c7.tar.gz
meson-a111c28ecef721af960721c26b40f4e5108760c7.tar.bz2
Add support for detecting free-threaded Python on Windows
This does a couple of things: 1. Scrape the `Py_GIL_DISABLED` sysconfig var, which is the best way as of today to determine whether the target interpreter was built with `--disable-gil` 2. link against the correct libpython 3. On Windows, work around a known issue in the python.org installer with a missing define in `pyconfig.h`, which the CPython devs have said is unlikely to be fixed since headers are shared between the regular and free-threaded builds in a single NSIS installer.
Diffstat (limited to 'mesonbuild/scripts')
-rwxr-xr-xmesonbuild/scripts/python_info.py4
1 files changed, 4 insertions, 0 deletions
diff --git a/mesonbuild/scripts/python_info.py b/mesonbuild/scripts/python_info.py
index 5b048ca..6aab380 100755
--- a/mesonbuild/scripts/python_info.py
+++ b/mesonbuild/scripts/python_info.py
@@ -106,6 +106,9 @@ if sys.version_info >= (3, 2):
if is_pypy:
limited_api_suffix = suffix
+# Whether we're targeting a free-threaded CPython interpreter
+is_freethreaded = bool(variables.get('Py_GIL_DISABLED', False))
+
print(json.dumps({
'variables': variables,
'paths': paths,
@@ -118,4 +121,5 @@ print(json.dumps({
'link_libpython': links_against_libpython(),
'suffix': suffix,
'limited_api_suffix': limited_api_suffix,
+ 'is_freethreaded': is_freethreaded,
}))