Rollup merge of #125818 - Urgau:print-check-cfg-no-values, r=petrochenkov

Handle no values cfgs with `--print=check-cfg`

This PR fix a bug with `--print=check-cfg`, where no values cfgs where not printed since we only printed cfgs that had at least one values.

The representation I choose is `CFG=`, since it doesn't correspond to any valid config, it also IMO nicely complements the `values()` (to indicate no values). Representing the absence of value by the absence of the value.

So for `cfg(feature, values())` we would print `feature=`.

I also added the missing tracking issue number in the doc.

r? ```@petrochenkov```
This commit is contained in:
许杰友 Jieyou Xu (Joe) 2024-06-04 08:25:48 +01:00 committed by GitHub
commit 756af9d5bc
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
3 changed files with 27 additions and 8 deletions

View file

@ -814,13 +814,17 @@ fn print_crate_info(
match expected_values { match expected_values {
ExpectedValues::Any => check_cfgs.push(format!("{name}=any()")), ExpectedValues::Any => check_cfgs.push(format!("{name}=any()")),
ExpectedValues::Some(values) => { ExpectedValues::Some(values) => {
check_cfgs.extend(values.iter().map(|value| { if !values.is_empty() {
if let Some(value) = value { check_cfgs.extend(values.iter().map(|value| {
format!("{name}=\"{value}\"") if let Some(value) = value {
} else { format!("{name}=\"{value}\"")
name.to_string() } else {
} name.to_string()
})) }
}))
} else {
check_cfgs.push(format!("{name}="))
}
} }
} }
} }

View file

@ -1,6 +1,6 @@
# `print=check-cfg` # `print=check-cfg`
The tracking issue for this feature is: [#XXXXXX](https://github.com/rust-lang/rust/issues/XXXXXX). The tracking issue for this feature is: [#125704](https://github.com/rust-lang/rust/issues/125704).
------------------------ ------------------------
@ -15,6 +15,7 @@ This print option works similarly to `--print=cfg` (modulo check-cfg specifics):
- `cfg(feature, values("foo", "bar"))`: `feature="foo"` and `feature="bar"` - `cfg(feature, values("foo", "bar"))`: `feature="foo"` and `feature="bar"`
- `cfg(feature, values(none(), ""))`: `feature` and `feature=""` - `cfg(feature, values(none(), ""))`: `feature` and `feature=""`
- `cfg(feature, values(any()))`: `feature=any()` - `cfg(feature, values(any()))`: `feature=any()`
- `cfg(feature, values())`: `feature=`
- `cfg(any())`: `any()` - `cfg(any())`: `any()`
- *nothing*: `any()=any()` - *nothing*: `any()=any()`

View file

@ -48,6 +48,20 @@ fn main() {
doesnt_contain: &["any()", "any()=any()", "feature=none()", "feature="], doesnt_contain: &["any()", "any()=any()", "feature=none()", "feature="],
}, },
}); });
check(CheckCfg {
args: &["--check-cfg=cfg(feature, values())"],
contains: Contains::Some {
contains: &["feature="],
doesnt_contain: &["any()", "any()=any()", "feature=none()", "feature"],
},
});
check(CheckCfg {
args: &["--check-cfg=cfg(feature, values())", "--check-cfg=cfg(feature, values(none()))"],
contains: Contains::Some {
contains: &["feature"],
doesnt_contain: &["any()", "any()=any()", "feature=none()", "feature="],
},
});
check(CheckCfg { check(CheckCfg {
args: &[ args: &[
r#"--check-cfg=cfg(feature, values(any()))"#, r#"--check-cfg=cfg(feature, values(any()))"#,