From 58661d299edce9a794870dcb7d63a5b7cc4a189a Mon Sep 17 00:00:00 2001 From: Ed Page Date: Mon, 9 Dec 2024 10:28:52 -0600 Subject: [PATCH] fix(build-rs): Implicitly report `rerun-if-env-changed` for `input` As we abstract aware the env variables, users can't do a good job of reporting these, so we'll do it ourselves. We could make the traits public and take and explicit `env` parameter. I figured we can wait until there is a motivating use case. `build_env` does have a fancier `Env` impl where you pass it HOST and TARGET and it automatically looks up values for those with a fallback scheme. --- crates/build-rs/src/input.rs | 83 ++++++++++++++++++++++-------------- 1 file changed, 52 insertions(+), 31 deletions(-) diff --git a/crates/build-rs/src/input.rs b/crates/build-rs/src/input.rs index 8e58868b466..b83f4d2a148 100644 --- a/crates/build-rs/src/input.rs +++ b/crates/build-rs/src/input.rs @@ -9,6 +9,9 @@ use std::path::PathBuf; use crate::ident::{is_ascii_ident, is_crate_name, is_feature_name}; +use crate::output::rerun_if_env_changed; + +const ENV: RerunIfEnvChanged = RerunIfEnvChanged::new(); /// Abstraction over environment variables trait Env { @@ -41,6 +44,28 @@ impl Env for ProcessEnv { } } +/// [`Env`] wrapper that implicit calls [`rerun_if_env_changed`] +struct RerunIfEnvChanged(E); + +impl RerunIfEnvChanged { + const fn new() -> Self { + Self(ProcessEnv) + } +} + +impl Env for RerunIfEnvChanged { + #[track_caller] + fn get(&self, key: &str) -> Option { + rerun_if_env_changed(key); + self.0.get(key) + } + + #[track_caller] + fn is_present(&self, key: &str) -> bool { + self.get(key).is_some() + } +} + /// Path to the `cargo` binary performing the build. #[track_caller] pub fn cargo() -> PathBuf { @@ -60,8 +85,7 @@ pub fn cargo_manifest_dir() -> PathBuf { /// The path to the manifest of your package. #[track_caller] pub fn cargo_manifest_path() -> PathBuf { - ProcessEnv - .get("CARGO_MANIFEST_PATH") + ENV.get("CARGO_MANIFEST_PATH") .map(to_path) .unwrap_or_else(|| { let mut path = cargo_manifest_dir(); @@ -73,7 +97,7 @@ pub fn cargo_manifest_path() -> PathBuf { /// The manifest `links` value. #[track_caller] pub fn cargo_manifest_links() -> Option { - ProcessEnv.get("CARGO_MANIFEST_LINKS").map(to_string) + ENV.get("CARGO_MANIFEST_LINKS").map(to_string) } /// Contains parameters needed for Cargo’s [jobserver] implementation to parallelize @@ -88,7 +112,7 @@ pub fn cargo_manifest_links() -> Option { /// [jobserver]: https://www.gnu.org/software/make/manual/html_node/Job-Slots.html #[track_caller] pub fn cargo_makeflags() -> Option { - ProcessEnv.get("CARGO_MAKEFLAGS").map(to_string) + ENV.get("CARGO_MAKEFLAGS").map(to_string) } /// For each activated feature of the package being built, this will be `true`. @@ -99,7 +123,7 @@ pub fn cargo_feature(name: &str) -> bool { } let name = name.to_uppercase().replace('-', "_"); let key = format!("CARGO_FEATURE_{name}"); - ProcessEnv.is_present(&key) + ENV.is_present(&key) } /// For each [configuration option] of the package being built, this will contain @@ -113,7 +137,7 @@ pub fn cargo_feature(name: &str) -> bool { #[track_caller] pub fn cargo_cfg(cfg: &str) -> Option> { let var = cargo_cfg_var(cfg); - ProcessEnv.get(&var).map(|v| to_strings(v, ',')) + ENV.get(&var).map(|v| to_strings(v, ',')) } #[track_caller] @@ -136,7 +160,7 @@ mod cfg { #[cfg(any())] #[track_caller] pub fn cargo_cfg_clippy() -> bool { - ProcessEnv.is_present("CARGO_CFG_CLIPPY") + ENV.is_present("CARGO_CFG_CLIPPY") } /// If we are compiling with debug assertions enabled. @@ -147,25 +171,25 @@ mod cfg { #[cfg(any())] #[track_caller] pub fn cargo_cfg_debug_assertions() -> bool { - ProcessEnv.is_present("CARGO_CFG_DEBUG_ASSERTIONS") + ENV.is_present("CARGO_CFG_DEBUG_ASSERTIONS") } #[cfg(any())] #[track_caller] pub fn cargo_cfg_doc() -> bool { - ProcessEnv.is_present("CARGO_CFG_DOC") + ENV.is_present("CARGO_CFG_DOC") } #[cfg(any())] #[track_caller] pub fn cargo_cfg_docsrs() -> bool { - ProcessEnv.is_present("CARGO_CFG_DOCSRS") + ENV.is_present("CARGO_CFG_DOCSRS") } #[cfg(any())] #[track_caller] pub fn cargo_cfg_doctest() -> bool { - ProcessEnv.is_present("CARGO_CFG_DOCTEST") + ENV.is_present("CARGO_CFG_DOCTEST") } /// The level of detail provided by derived [`Debug`] implementations. @@ -179,7 +203,7 @@ mod cfg { #[cfg(any())] #[track_caller] pub fn cargo_cfg_miri() -> bool { - ProcessEnv.is_present("CARGO_CFG_MIRI") + ENV.is_present("CARGO_CFG_MIRI") } /// If we are compiling with overflow checks enabled. @@ -187,7 +211,7 @@ mod cfg { #[cfg(feature = "unstable")] #[track_caller] pub fn cargo_cfg_overflow_checks() -> bool { - ProcessEnv.is_present("CARGO_CFG_OVERFLOW_CHECKS") + ENV.is_present("CARGO_CFG_OVERFLOW_CHECKS") } /// The [panic strategy](https://doc.rust-lang.org/stable/reference/conditional-compilation.html#panic). @@ -199,7 +223,7 @@ mod cfg { /// If the crate is being compiled as a procedural macro. #[track_caller] pub fn cargo_cfg_proc_macro() -> bool { - ProcessEnv.is_present("CARGO_CFG_PROC_MACRO") + ENV.is_present("CARGO_CFG_PROC_MACRO") } /// The target relocation model. @@ -213,7 +237,7 @@ mod cfg { #[cfg(any())] #[track_caller] pub fn cargo_cfg_rustfmt() -> bool { - ProcessEnv.is_present("CARGO_CFG_RUSTFMT") + ENV.is_present("CARGO_CFG_RUSTFMT") } /// Sanitizers enabled for the crate being compiled. @@ -221,9 +245,7 @@ mod cfg { #[cfg(feature = "unstable")] #[track_caller] pub fn cargo_cfg_sanitize() -> Option> { - ProcessEnv - .get("CARGO_CFG_SANITIZE") - .map(|v| to_strings(v, ',')) + ENV.get("CARGO_CFG_SANITIZE").map(|v| to_strings(v, ',')) } /// If CFI sanitization is generalizing pointers. @@ -231,7 +253,7 @@ mod cfg { #[cfg(feature = "unstable")] #[track_caller] pub fn cargo_cfg_sanitizer_cfi_generalize_pointers() -> bool { - ProcessEnv.is_present("CARGO_CFG_SANITIZER_CFI_GENERALIZE_POINTERS") + ENV.is_present("CARGO_CFG_SANITIZER_CFI_GENERALIZE_POINTERS") } /// If CFI sanitization is normalizing integers. @@ -239,7 +261,7 @@ mod cfg { #[cfg(feature = "unstable")] #[track_caller] pub fn cargo_cfg_sanitizer_cfi_normalize_integers() -> bool { - ProcessEnv.is_present("CARGO_CFG_SANITIZER_CFI_NORMALIZE_INTEGERS") + ENV.is_present("CARGO_CFG_SANITIZER_CFI_NORMALIZE_INTEGERS") } /// Disambiguation of the [target ABI](https://doc.rust-lang.org/stable/reference/conditional-compilation.html#target_abi) @@ -335,7 +357,7 @@ mod cfg { #[cfg(feature = "unstable")] #[track_caller] pub fn cargo_cfg_target_thread_local() -> bool { - ProcessEnv.is_present("CARGO_CFG_TARGET_THREAD_LOCAL") + ENV.is_present("CARGO_CFG_TARGET_THREAD_LOCAL") } /// The [target vendor](https://doc.rust-lang.org/stable/reference/conditional-compilation.html#target_vendor). @@ -347,7 +369,7 @@ mod cfg { #[cfg(any())] #[track_caller] pub fn cargo_cfg_test() -> bool { - ProcessEnv.is_present("CARGO_CFG_TEST") + ENV.is_present("CARGO_CFG_TEST") } /// If we are compiling with UB checks enabled. @@ -355,19 +377,19 @@ mod cfg { #[cfg(feature = "unstable")] #[track_caller] pub fn cargo_cfg_ub_checks() -> bool { - ProcessEnv.is_present("CARGO_CFG_UB_CHECKS") + ENV.is_present("CARGO_CFG_UB_CHECKS") } /// Set on [unix-like platforms](https://doc.rust-lang.org/stable/reference/conditional-compilation.html#unix-and-windows). #[track_caller] pub fn cargo_cfg_unix() -> bool { - ProcessEnv.is_present("CARGO_CFG_UNIX") + ENV.is_present("CARGO_CFG_UNIX") } /// Set on [windows-like platforms](https://doc.rust-lang.org/stable/reference/conditional-compilation.html#unix-and-windows). #[track_caller] pub fn cargo_cfg_windows() -> bool { - ProcessEnv.is_present("CARGO_CFG_WINDOWS") + ENV.is_present("CARGO_CFG_WINDOWS") } } @@ -454,7 +476,7 @@ pub fn dep_metadata(name: &str, key: &str) -> Option { let name = name.to_uppercase().replace('-', "_"); let key = key.to_uppercase().replace('-', "_"); let key = format!("DEP_{name}_{key}"); - ProcessEnv.get(&key).map(to_string) + ENV.get(&key).map(to_string) } /// The compiler that Cargo has resolved to use. @@ -474,7 +496,7 @@ pub fn rustdoc() -> PathBuf { /// [`build.rustc-wrapper`]: https://doc.rust-lang.org/stable/cargo/reference/config.html#buildrustc-wrapper #[track_caller] pub fn rustc_wrapper() -> Option { - ProcessEnv.get("RUSTC_WRAPPER").map(to_path) + ENV.get("RUSTC_WRAPPER").map(to_path) } /// The rustc wrapper, if any, that Cargo is using for workspace members. See @@ -483,7 +505,7 @@ pub fn rustc_wrapper() -> Option { /// [`build.rustc-workspace-wrapper`]: https://doc.rust-lang.org/stable/cargo/reference/config.html#buildrustc-workspace-wrapper #[track_caller] pub fn rustc_workspace_wrapper() -> Option { - ProcessEnv.get("RUSTC_WORKSPACE_WRAPPER").map(to_path) + ENV.get("RUSTC_WORKSPACE_WRAPPER").map(to_path) } /// The linker that Cargo has resolved to use for the current target, if specified. @@ -491,7 +513,7 @@ pub fn rustc_workspace_wrapper() -> Option { /// [`target.*.linker`]: https://doc.rust-lang.org/stable/cargo/reference/config.html#targettriplelinker #[track_caller] pub fn rustc_linker() -> Option { - ProcessEnv.get("RUSTC_LINKER").map(to_path) + ENV.get("RUSTC_LINKER").map(to_path) } /// Extra flags that Cargo invokes rustc with. See [`build.rustflags`]. @@ -589,8 +611,7 @@ pub fn cargo_pkg_readme() -> Option { #[track_caller] fn var_or_panic(key: &str) -> std::ffi::OsString { - ProcessEnv - .get(key) + ENV.get(key) .unwrap_or_else(|| panic!("cargo environment variable `{key}` is missing")) }