Skip to content

Commit 471fa05

Browse files
committed
Make #[cfg(bootstrap)] not error in proc macros on later stages
As was discovered in #93628 (comment) , adding #[cfg(bootstrap)] to a rust-internal proc macro crate would yield an unexpected cfg name error, at least on later stages wher the bootstrap cfg arg wasn't set. rustc already passes arguments to mark bootstrap as expected, however the means of delivery through the RUSTFLAGS env var is unable to reach proc macro crates, as described in the issue linked in the code this commit touches. This wouldn't be an issue for cfg args that get passed through RUSTFLAGS, as they would never become *active* either, so any usage of one of these flags in a proc macro's code would legitimately yield a lint warning. But since dc30258, rust takes extra measures to pass --cfg=bootstrap even in proc macros, by passing it via the wrapper. Thus, we need to send the flags to mark bootstrap as expected also from the wrapper, so that #[cfg(bootstrap)] also works from proc macros. I want to thank Urgau and jplatte for helping me find the cause of this. ❤️
1 parent 3bdec3c commit 471fa05

File tree

1 file changed

+9
-3
lines changed

1 file changed

+9
-3
lines changed

src/bootstrap/bin/rustc.rs

+9-3
Original file line numberDiff line numberDiff line change
@@ -127,12 +127,18 @@ fn main() {
127127
}
128128
}
129129

130+
// Cargo doesn't pass RUSTFLAGS to proc_macros:
131+
// https://github.com/rust-lang/cargo/issues/4423
132+
// Thus, if we are on stage 0, we explicitly set `--cfg=bootstrap`.
133+
// We also declare that the flag is expected, which is mainly needed for
134+
// later stages so that they don't warn about #[cfg(bootstrap)],
135+
// but enabling it for stage 0 too lets any warnings, if they occur,
136+
// occur more early on, e.g. about #[cfg(bootstrap = "foo")].
130137
if stage == "0" {
131-
// Cargo doesn't pass RUSTFLAGS to proc_macros:
132-
// https://github.com/rust-lang/cargo/issues/4423
133-
// Set `--cfg=bootstrap` explicitly instead.
134138
cmd.arg("--cfg=bootstrap");
135139
}
140+
cmd.arg("-Zunstable-options");
141+
cmd.arg("--check-cfg=values(bootstrap)");
136142
}
137143

138144
if let Ok(map) = env::var("RUSTC_DEBUGINFO_MAP") {

0 commit comments

Comments
 (0)