-
Notifications
You must be signed in to change notification settings - Fork 1.6k
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
rustflags in .cargo/config cause rebuilds when running "cargo build" #5828
Comments
I've noticed the same thing on linux when using
Every change in my source will cause rust-analyzer to re-check all my dependencies, and cause builds to re-build all dependencies. |
I have the same issue with RUSTFLAGS variable |
I'm also experiencing this issue. #3544 or inlining rustflags would work, I think. |
I am honestly a bit surprised how this can even happen as we merely invoke cargo ourselves from what I know. In which case this should also use the flags from
|
I had the same problem but it was because I had a wasm library in my workspace. Now I can't reproduce this issue. |
After some investigation I found that constant rebuilds in my case were caused by the NFS, i.e. cargo artifacts were created on the network drive, which cased cargo to think they were out of date. Once I set CARGO_TARGET_DIR to point to my local drive, the issue disappeared. |
I just went and checked and this shouldn't happen anymore as long as the user sets the exact same flags in |
I encounter this issue as well as #4616 whenever I cross compile, save an edit in Kate, then go to cross compile again. This happens both with GNU ld and mold as linkers. With GNU ld, in ~/.cargo/config.toml I have:
For mold:
My host is x86_64-unknown-linux-gnu.
That is not a practical solution when developing for multiple targets each with their own compiler flags. |
Unfortunately, we are also experiencing this issue. Duplicating and maintaining common |
r-a isn't able to do much here. This is inherent to how cargo works. The best option here is to set |
What about this is inherent to how Cargo works? Cargo respects Edit: Setting Edit 2: For more context, this appears to only be an issue when compiling for |
It should, every cargo command r-a invokes respects the config.toml, even querying metadata should now. Do you have a small repro by any chance? |
I don't have a small one ATM, but I'll try to make one. |
Also being impacted by this issue. Very frustrating to try to work around. Even setting a different target directory for rust-analyzer with checkOnSave.extraArgs doesn't help; rust-analyzer continues to trigger full rebuilds. Also using wasm32-unknown-unknown as part of the workspace. |
How are you setting the target when compiling for wasm? If you do it manually then you'll have to set the target for |
@Veykril The cargo workspace I'm using has multiple crates with different build targets, so setting that value at the project level won't work. This seems to be an ongoing weakness with Rust tooling for wasm projects. The community clearly wants support of multi-target workspaces to build both wasm code in addition to server or tooling code with different build targets. Cargo sort of supports this right now with rust-lang/cargo#9406 (only in nightly), but overall the cargo maintainers don't seem to view this as a priority. Would rust-analyzer respect per_package_target if I set that option in each crate's Cargo.toml and used the nightly toolchain? If it won't, I think the workaround here is to just get rust-analyzer to respect the target dir override, but this isn't currently working for me. I'm still seeing the normal target dir being used even with the following config: |
r-a won't respect the per_package_target no Regarding the target dir env var, thats odd, all cargo processes spawned by r-a should inherit those env vars |
@Veykril Thanks for the response. I've made a quick sample repository to show the issue (https://github.com/willhodges/rabug); if you pull this repository down and open the top-level folder in VSCode (with rust-analyzer extension) or Atom (with ide-rust extension, which uses rust-analyzer under the hood) they will both kick off rust-analyzer, which creates the target directory, and then target/check and target/debug, which I believe suggests that r-a is ignoring the CARGO_TARGET_DIR in rust-analyzer.json. It's hard to guarantee that that is true without being able to run r-a directly instead of relying on the editor to do it indirectly. I'd be happy to learn that I'm wrong here. |
can you create a new issue for that? Otherwise this will be overlooked as this issue is about rustflags specifically |
@Veykril I'm seeing this issue now even without using rust-analyzer, so it appears to be an issue with Cargo itself, likely this one: rust-lang/cargo#10839 |
I have a
.cargo/config
file to make cargo use lld on x86_64 Linux.This causes
cargo build
when run manually to behave differently from when run from rust-analyzer, thus all crates are rebuilt. This is rather annoying when I perform test runs of my binary usingcargo run
as it needs to rebuilt everything, and then rust-analyzer rebuilds everything again once I return to vim.The text was updated successfully, but these errors were encountered: