Skip to content
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

Add Rust support to build-wheel #1030

Open
mhsmith opened this issue Nov 28, 2023 · 8 comments
Open

Add Rust support to build-wheel #1030

mhsmith opened this issue Nov 28, 2023 · 8 comments

Comments

@mhsmith
Copy link
Member

mhsmith commented Nov 28, 2023

Several packages are blocked until we do this – see the cross-references below.

@mhsmith
Copy link
Member Author

mhsmith commented Nov 28, 2023

We have two examples so far of Python/Rust packages being successfully built for Android:

  • The existing tokenizers recipe, which does it by inserting a large block into the setup.py script using a patch. This doesn't easily generalize to other packages, and it hasn't been updated since early 2022, so it will require updates to work with the current version of build-wheel.

  • The new cryptography recipe by @emanuele-f (#827, #657), which requires a large number of manual actions, including rebuilding Python because the Python/Rust bridge PyO3 requires a separate sysconfigdata file for each ABI (see comment in unpackage-target.sh).

A proper solution would work as follows:

  • Alter the build and packging scripts of Python itself (in the target directory) to preserve all the sysconfigdata files.

  • Make build-wheel recognize a meta.yaml build requirement of rust, just as it currently recognizes fortran, and respond by setting up the Rust compiler and environment variables as necessary.

@divyanshluthra
Copy link

sounds like a pretty big task

@IsakTheHacker
Copy link
Contributor

@mhsmith In som other issue, I think you mentioned that the whole package repository is being deprecated. Is Rust support for the build wheel tool (this issue) still a feature that you are willing to receive PRs for or is all work being put here redundant since Python is going to get official Android support anyway?

@mhsmith
Copy link
Member Author

mhsmith commented Aug 13, 2024

I would still accept a PR that fixed this in build-wheel, because the content of that solution would be useful for future work with the upstream Python/Rust ecosystem anyway.

However, it's probably better if you don't work on the "preserve all the sysconfigdata files" step above, because I'll be revisiting the Python build process soon as part of adding Python 3.13 support (#1210).

@mhsmith
Copy link
Member Author

mhsmith commented Oct 8, 2024

In #1257 I'll update the packaging script so that the stdlib artifact for Python 3.13 will include the sysconfigdata files from all ABIs. After that, the next steps would be:

  • Update build-wheel to use this artifact and make the files available to Rust.
  • Work out how to deal with Python 3.12 and older, where multiple sysconfigdata files can't currently coexist because they all have the same name.

@emanuele-f
Copy link
Contributor

Hi @mhsmith , I have huge updates for the cryptography module, sysconfigdata is not necessary anymore for it and integration is much easier. I just need to clean things up, I will open a PR tomorrow

@emanuele-f
Copy link
Contributor

See #1261

@mhsmith
Copy link
Member Author

mhsmith commented Oct 17, 2024

@emanuele-f: Thanks very much, this is a huge step forward.

If anyone wants to try building one of the other Rust-based packages, you can now use the cryptography recipe as an example. I'll leave this issue open until we've had a few more successes.

@mhsmith mhsmith mentioned this issue Jan 7, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

4 participants