-
Notifications
You must be signed in to change notification settings - Fork 119
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Support building free-threaded CPython #319
base: main
Are you sure you want to change the base?
Conversation
Add support for Python's free threading build mode where the global interpreter lock is disabled. The packages are marked using a suffix on the architecture, like 'x64-freethreaded' or 'arm64-freethreaded'.
@mayeut suggested using the "arch" field in actions/setup-python#771 (comment). It's not a perfect fit, but it seems better than any other option to me. In particular, I experimented with using "+freethreaded" as a semver build metadata like uv does (e.g., "3.13.0+freethreaded"), but that doesn't work because:
|
Regarding the macOS & Windows installs, I think it uninstalls before installing which might mess up things depending on how setup-python is called (especially with multiple installs at once or in multiple steps). For Windows: This would remove all the uninstall & registry bits (this last one might interfere with the py launcher though but given this adds support for a new variant, I don't think it matters much for now). cibuildwheel uses this source for Windows CPython: https://github.com/pypa/cibuildwheel/blob/5cdddb2d4696110e00029b0b615799855912564d/cibuildwheel/windows.py#L108-L121 Building the package could be installing the nugget package to a temp dir & zipping the correct folder. |
@mayeut - I'm not sure I understand your concern. The uninstall step is part of creating the python-versions package, not setup-python. I don't see the problem and using a different installation method just for the freethreading package seems more risky and harder to maintain. You can run |
@colesbury, you're right. I misread the That being said, there's another point worth mentioning, the free threaded binaries are not embedded in the package but they are downloaded when installing (the offline installer only has the default options embedded, that means no free threaded binaries). Using the nuget installation method, everything needed will be in the built package without the need to download anything else upon install by Running setup-python with multiple versions fails on Linux: https://github.com/mayeut/sandbox/actions/runs/11825252827/job/32948605164 |
@priyagupta108 @gowridurgad @aparnajyothi-y - I'd appreciate it if you could take a look at this PR. |
Hello @colesbury 👋, |
Hello again @colesbury👋, During our testing of this PR, we noticed the following issues:
We would greatly appreciate it if you could address these issues at your earliest convenience. Thank you so much for your cooperation. |
Hi @priya-kinthali, thank you for reviewing this PR.
|
This matches the macOS behavior and allows users to install both the free-threading and default builds at the same time.
Hi @priya-kinthali, for (3), I've updated the Linux installer script so that installing 3.13.0t won't delete the installation of 3.13.0 and vice versa. |
Add support for Python's free threading build mode where the global interpreter lock is disabled. The packages are marked using a suffix on the architecture, like 'x64-freethreaded' or 'arm64-freethreaded'.
See actions/setup-python#771.