-
Notifications
You must be signed in to change notification settings - Fork 894
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
Make rustup update
completely update the default target before working on others
#4109
Comments
I don't think we currently make a distinction between rust-std and other components when updating so that would need to be changed. Correct me if I'm wrong. Using a toolchain while components are being installed is tricky because it involves modifying the toolchain directory. Rustup is not currently safe for that kind of thing. Though I think resolving #3937 would help here. |
@ChrisDenton I think #3937 will make this even harder since the client will be blocked when we are installing the active toolchain... @tgross35 While I do understand your frustrations, I think the right direction to go is something like https://github.com/dtolnay/fast-rustup. Installing toolchains in Rustup is definitely taking much longer than it should, especially if you have access to high-speed internet. |
I mean, we can block only when necessary right? We download to a cache so blocking only needs to happen when moving files from the cache to the toolchain directory. The downloads can happen in the background. |
One thing I'm wondering about is the most important thing to get a new toolchain up and running asap? Or is it to have the old nightly be usable right up until the new nightly is actually ready? The latter case would be simpler, I think. |
The ordering description doesn't make sense to me - last I saw the code we do an entire toolchain at a time. @rami3l - has anything changed around that? @tgross35 you can do A possibly nice little feature is to allow |
Oh, I took the OP as meaning about targets. Like if your toolchain has a lot of targets installed then updating all those |
Indeed, in my original description I used toolchain to refer to channel+target. I updated this to be specific about target, I always use |
rustup update
completely update the default toolchain before working on othersrustup update
completely update the default target before working on others
Problem you are trying to solve
For anyone who has multiple targets installed, completing a
rustup update
can take quite a while. It seems the order of operations is:rust-std
for all installed targetscargo
,rust-src
, and other componentsrust-std
for the native/default target (?)rustc
However, often times only the default target is of immediate interest.
Solution you'd like
Instead, do something like the following order:
rustc
rust-std
for the default toolchain/targetThis should make it feasible to start working with the most commonly used target within a couple of minutes while everything else updates in the background.
Notes
No response
The text was updated successfully, but these errors were encountered: