Prepare bootstrap tool for new check-cfg syntax

This commit is contained in:
Urgau 2023-10-20 17:47:22 +02:00
parent 8501f1c7ba
commit 276a34666b
2 changed files with 28 additions and 8 deletions

View File

@ -70,7 +70,9 @@ fn main() {
cmd.arg("--cfg=bootstrap"); cmd.arg("--cfg=bootstrap");
} }
cmd.arg("-Zunstable-options"); cmd.arg("-Zunstable-options");
// #[cfg(bootstrap)]
cmd.arg("--check-cfg=values(bootstrap)"); cmd.arg("--check-cfg=values(bootstrap)");
// cmd.arg("--check-cfg=cfg(bootstrap)");
if verbose > 1 { if verbose > 1 {
eprintln!( eprintln!(

View File

@ -1401,19 +1401,28 @@ impl<'a> Builder<'a> {
rustflags.arg("-Zunstable-options"); rustflags.arg("-Zunstable-options");
} }
// Enable cfg checking of cargo features for everything but std and also enable cfg // #[cfg(bootstrap)] should remove every code path where it's false
// checking of names and values. const USE_NEW_CHECK_CFG_SYNTAX: bool = false;
// Enable compile-time checking of `cfg` names, values and Cargo `features`.
// //
// Note: `std`, `alloc` and `core` imports some dependencies by #[path] (like // Note: `std`, `alloc` and `core` imports some dependencies by #[path] (like
// backtrace, core_simd, std_float, ...), those dependencies have their own // backtrace, core_simd, std_float, ...), those dependencies have their own
// features but cargo isn't involved in the #[path] process and so cannot pass the // features but cargo isn't involved in the #[path] process and so cannot pass the
// complete list of features, so for that reason we don't enable checking of // complete list of features, so for that reason we don't enable checking of
// features for std crates. // features for std crates.
cargo.arg(if mode != Mode::Std { if USE_NEW_CHECK_CFG_SYNTAX {
"-Zcheck-cfg=names,values,output,features" cargo.arg("-Zcheck-cfg");
if mode == Mode::Std {
rustflags.arg("--check-cfg=cfg(feature,values(any()))");
}
} else { } else {
"-Zcheck-cfg=names,values,output" cargo.arg(if mode != Mode::Std {
}); "-Zcheck-cfg=names,values,output,features"
} else {
"-Zcheck-cfg=names,values,output"
});
}
// Add extra cfg not defined in/by rustc // Add extra cfg not defined in/by rustc
// //
@ -1433,7 +1442,12 @@ impl<'a> Builder<'a> {
.collect::<String>(), .collect::<String>(),
None => String::new(), None => String::new(),
}; };
rustflags.arg(&format!("--check-cfg=values({name}{values})")); if USE_NEW_CHECK_CFG_SYNTAX {
let values = values.strip_prefix(",").unwrap_or(&values); // remove the first `,`
rustflags.arg(&format!("--check-cfg=cfg({name},values({values}))"));
} else {
rustflags.arg(&format!("--check-cfg=values({name}{values})"));
}
} }
} }
@ -1449,7 +1463,11 @@ impl<'a> Builder<'a> {
// We also declare that the flag is expected, which we need to do to not // We also declare that the flag is expected, which we need to do to not
// get warnings about it being unexpected. // get warnings about it being unexpected.
hostflags.arg("-Zunstable-options"); hostflags.arg("-Zunstable-options");
hostflags.arg("--check-cfg=values(bootstrap)"); if USE_NEW_CHECK_CFG_SYNTAX {
hostflags.arg("--check-cfg=cfg(bootstrap)");
} else {
hostflags.arg("--check-cfg=values(bootstrap)");
}
// FIXME: It might be better to use the same value for both `RUSTFLAGS` and `RUSTDOCFLAGS`, // FIXME: It might be better to use the same value for both `RUSTFLAGS` and `RUSTDOCFLAGS`,
// but this breaks CI. At the very least, stage0 `rustdoc` needs `--cfg bootstrap`. See // but this breaks CI. At the very least, stage0 `rustdoc` needs `--cfg bootstrap`. See