-
Notifications
You must be signed in to change notification settings - Fork 2.5k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat(build-script): Pass CARGO_CFG_FEATURE
This may look redundant with `CARGO_FEATURE_<CASE_CONVERTED_NAME>=1` except that doesn't provide a lossless way of getting the names, e.g. for forwarding for child builds like tests that need to build examples. This also makes things more consistent as users conditionalize on features through `cfg` and this even fits with what the `CARGO_CFG_` docs say: > For each configuration option of the package being built, this > environment variable will contain the value of the configuration, where > <cfg> is the name of the configuration uppercased and having - > translated to _. Boolean configurations are present if they are set, and > not present otherwise. Configurations with multiple values are joined to > a single variable with the values delimited by ,. This includes values > built-in to the compiler (which can be seen with rustc --print=cfg) and > values set by build scripts and extra flags passed to rustc (such as > those defined in RUSTFLAGS). Some examples of what these variables are: Fixes #3702
- Loading branch information
Showing
6 changed files
with
32 additions
and
3 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -156,7 +156,7 @@ fn custom_build_env_vars() { | |
authors = ["[email protected]"] | ||
[features] | ||
bar_feat = ["bar/foo"] | ||
bar_feat = ["bar/foo", "bar/other"] | ||
[dependencies.bar] | ||
path = "bar" | ||
|
@@ -176,6 +176,7 @@ fn custom_build_env_vars() { | |
[features] | ||
foo = [] | ||
other = [] | ||
"#, | ||
) | ||
.file("bar/src/lib.rs", "pub fn hello() {}"); | ||
|
@@ -213,6 +214,8 @@ fn custom_build_env_vars() { | |
let _host = env::var("HOST").unwrap(); | ||
let _feat = env::var("CARGO_FEATURE_FOO").unwrap(); | ||
let feat = env::var("CARGO_CFG_FEATURE").unwrap(); | ||
assert_eq!(feat, "foo,other"); | ||
let cargo = env::var("CARGO").unwrap(); | ||
if env::var_os("CHECK_CARGO_IS_RUSTC").is_some() {{ | ||
|