Prepare bootstrap tool for new check-cfg syntax
This commit is contained in:
parent
8501f1c7ba
commit
276a34666b
@ -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!(
|
||||||
|
@ -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
|
||||||
|
Loading…
x
Reference in New Issue
Block a user