-
-
Notifications
You must be signed in to change notification settings - Fork 278
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
Install rust toolchain on building source distribution #2120
Comments
I don't think this should be done in Even though gcc/clang is part of the major OS distributions, when using sdist, it's still possible that they are missing from the OS environment of the end user, in such case should |
Personally, i think a source distribution should install all build dependencies it needs; it should not be the responsibility of a python user to understand the native build system of their transitive dependencies only because they are let's say on an arm platform without wheels. We'd need a way to bootstrap rust and cargo for this though that doesn't change the users environment (like rustup does). It would be ideal to have wheels for cargo and rustc on pypi like we have with zig. Relying on (linux) distros is often insufficient, they require root access to install new packages that is not available in many environments and only ship specific versions of tools. It would honestly be amazing if we could get gcc and clang from pypi too. |
It sounds amazing but surely there will be people start complain that using sdist download lots of huge dependencies. IMO if it's really desirable, perhaps it should just be another dependency in |
We can check for rust and cargo in |
I'm fine with this solution if it works, but consider when a sdist requires a specific |
Totally, this would be limited to stable rust |
Thanks for the discussion. For me both options, an explicit extra dependency in |
I'll try to file a PR to address this in the coming few days |
Currently,
maturin
requires the rust toolchain (cargo
,rustc
) already to be installed. This is no problem in a development scenario as Rust developers presumably have Rust installed.However, when a user installs the source distribution of a package built with
maturin
, the user also requires the Rust toolchain, although they may be only interested in the package, but not in Rust. Rust is also not a part (yet) of the major OS distributions, so that user would need to go the extra mile of runningrustup
first.Therefore, I propose installing the Rust toolchain in an isolated environment (e.g. similar to https://github.com/chriskuehl/rustenv) when
maturin
is used as[build-system]
, at least in case the rust toolchain is not installed, yet.The text was updated successfully, but these errors were encountered: