-
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
Rerun-if-changed without disabling other heuristics as a side-effect #4587
Comments
The current semantics of
is effectively the same as without the
causes Cargo to still ignore the package sources due to a reference to an env-var and use IMHO The current implementation calls for the build-script to |
I'm also OK with changing the existing behavior to be additive without side effects, and adding another explicit option like |
Can disabling of built-in heuristics as a side effect be fixed (i.e. side-effect removed)? Does building more than necessary count as a breaking change? If so, can it be done as part of 2018 edition? |
Yes changing the default behavior would be a breaking change, but we could always add a new option for build scripts (or something like that) to say "use the default heuristics". Either that or a crate could be published to crates.io which is a one-liner to do what Cargo currently does. |
I'd love to have that option. This seems like a relatively straightforward addition to Cargo. Modulo bikeshedding the name, what would this take to add? A full RFC, or just a PR and consensus from the cargo team? |
Can you include some concrete use cases? Would this be for generic build libraries like pkg-config? Is this important for adding rerun-if for files outside of the package directory (like system libraries and binaries)? The default behavior is pretty dumb and covers all files in the package directory (modulo include/exclude/gitignore). It is pretty rare where that is the best behavior, so it is preferred for the script to turn off the default behavior and narrow its change detection scope. If there is a command to use default heuristics, then you couldn't turn it off? I think that would be bad if some generic library set that and then require the user to do something to turn it off. Is it more important for |
It is for build-time dependencies, which may know about some subset of env vars and files which definitely need to cause a rebuild, but are not in charge of building the whole crate, so they can't make a global change to the default heuristic behavior. Env vars are the primary use-case here. Env vars can significantly affect the build, but AFAIK they're not all automatically included in the default heuristics, so they really really should always be reported as affecting the build. For files it's more of a nice to have, since the default heuristic of watching all files is correct most of the time. |
The use case of build-time dependencies emitting build script output seems like an excellent argument against a global cargo directive for "keep the default heuristics", and an argument in favor of new directives for "add this environment variable but don't drop the defaults" and "add this file but don't drop the defaults". |
As a relevant example where this is causing trouble: prost_build which is used by various projects for generating code from protocol buffer specifications (and would ideally be able to automatically ensure such code is regenerated if the specifications change) currently shies away from emiting For my use case this then means I need to emit these lines manually, because I have .proto files that live outside of my project directory so the catch-all heuristics aren't enough. It's not clear to me what could go wrong with making Although it's technically a change in behaviour, projects are currently blocked from correctly handling dependencies automatically with this design which seems like a bigger issue than possibly triggering some redundant re-builds in some cases? |
From #6031, |
Another possible solution: add And the default behavior of |
A stopgap solution would be a crate that perfectly replicated Cargo's own heuristics, and offered an API to both add and remove things from the default watched set, but under the hood it would calculate all the files to be added and so work with current cargo. Maybe this crate? (not sure if this has all features needed, but I think to add something while keeping Cargo's heuristic is just a matter of issuing a normal Of course I would love to see this in Cargo proper. |
Currently any use rerun-if-changed opts in entire build into a completely "manual" tracking, disabling all built-in rules as a side effect. This means it's not possible to safely just add one file/env var check to the build without understanding all the dependencies of the entire build script.
In order to use rerun-if-changed features in build-time libraries without potentially breaking rest of the build, it's necessary to be able to use rerun-if-changed-like functionality without disabling the built-in heuristic (i.e. rerun if a var/file has changed in addition to all the other/default conditions that cause the build to be rebuilt).
rust-lang/pkg-config-rs#45 (comment)
bikeshed syntax:
cargo:rerun-if-also-changed=file
,cargo:rerun-if-changed+=file
,cargo:rerun-if-changed;keep-defaults=file
The text was updated successfully, but these errors were encountered: