-
Notifications
You must be signed in to change notification settings - Fork 2.5k
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
warn if rerun-if-changed=PATH is used but PATH points to none-existing file #6003
Comments
Another reasonable behavior (perhaps on top of the warning) is to rebuild only when the file is removed between builds or is created just before a new build (i.e. the file is "modified" in the sense that it went from existent to non-existent or vice versa). |
I agree with @remysucre that a warning is not necessarily appropriate. I came across the spurious rebuilding behavior described in this issue in the case of https://github.com/rust-lang/crates.io — they have a The behavior I would have expected is that Cargo remembers which rerun-if-changed files did not exist in the most recent build, and does not rebuild if they still do not exist. Could we consider the continual rebuilding behavior a bug? crates.io$ cargo check ... ... Finished dev [unoptimized + debuginfo] target(s) in 21.91s crates.io$ cargo check Compiling cargo-registry v0.2.2 Finished dev [unoptimized + debuginfo] target(s) in 3.21s crates.io$ cargo check Compiling cargo-registry v0.2.2 Finished dev [unoptimized + debuginfo] target(s) in 3.24s crates.io$ cargo check # each of these is a rebuild Compiling cargo-registry v0.2.2 Finished dev [unoptimized + debuginfo] target(s) in 3.19s crates.io$ touch .env crates.io$ cargo check Compiling cargo-registry v0.2.2 Finished dev [unoptimized + debuginfo] target(s) in 3.20s crates.io$ cargo check Finished dev [unoptimized + debuginfo] target(s) in 0.12s crates.io$ cargo check Finished dev [unoptimized + debuginfo] target(s) in 0.12s crates.io$ cargo check # no longer rebuilding now that .env exists Finished dev [unoptimized + debuginfo] target(s) in 0.12s |
There is a small backwards compatibility hazard for changing the behavior, if any project is relying on the way it works now. For example, I tried searching through crates.io, and I only found one that seemed to be doing this here. I found a few others that do I'm not sure if that's a big enough concern to block changing this behavior. I agree it is probably not the best behavior. A warning is an option, though I'm uncertain how likely that could trigger a false positive. It won't be trivial to implement because cargo does not track the status of every file (it just tracks the newest mtime). |
I recently ran into a weird bug where my project would always rebuild main.rs even though I didn't change any of its files.
Turned out in
build.rs
I hadrerun-if-changed=PATH
set to a wrongPATH
, aPATH
that never was any file, which caused to trigger rebuilds every time.Can we print a warning if the
PATH
is empty, or are there cases where this could be intended?The text was updated successfully, but these errors were encountered: