restore check for both target os and env

This is better than the old impl of target.ends_with("windows-gnu"),
because it also catches things like windows-gnullvm
This commit is contained in:
Pietro Albini 2023-03-16 11:34:18 +01:00
parent 5b0a0d8254
commit 9a2d1b85ed
No known key found for this signature in database
GPG key ID: CD76B35F7734769E
2 changed files with 15 additions and 0 deletions

View file

@ -409,6 +409,7 @@ pub struct TargetCfgs {
pub all_targets: HashSet<String>,
pub all_archs: HashSet<String>,
pub all_oses: HashSet<String>,
pub all_oses_and_envs: HashSet<String>,
pub all_envs: HashSet<String>,
pub all_abis: HashSet<String>,
pub all_families: HashSet<String>,
@ -433,6 +434,7 @@ impl TargetCfgs {
let mut all_targets = HashSet::new();
let mut all_archs = HashSet::new();
let mut all_oses = HashSet::new();
let mut all_oses_and_envs = HashSet::new();
let mut all_envs = HashSet::new();
let mut all_abis = HashSet::new();
let mut all_families = HashSet::new();
@ -441,6 +443,7 @@ impl TargetCfgs {
for (target, cfg) in targets.into_iter() {
all_archs.insert(cfg.arch.clone());
all_oses.insert(cfg.os.clone());
all_oses_and_envs.insert(cfg.os_and_env());
all_envs.insert(cfg.env.clone());
all_abis.insert(cfg.abi.clone());
for family in &cfg.families {
@ -459,6 +462,7 @@ impl TargetCfgs {
all_targets,
all_archs,
all_oses,
all_oses_and_envs,
all_envs,
all_abis,
all_families,
@ -506,6 +510,12 @@ pub struct TargetCfg {
panic: PanicStrategy,
}
impl TargetCfg {
pub(crate) fn os_and_env(&self) -> String {
format!("{}-{}", self.os, self.env)
}
}
fn default_os() -> String {
"none".into()
}

View file

@ -84,6 +84,11 @@ pub(super) fn parse_cfg_name_directive<'a>(
allowed_names: &target_cfgs.all_envs,
message: "when the target environment is {name}"
}
condition! {
name: &target_cfg.os_and_env(),
allowed_names: &target_cfgs.all_oses_and_envs,
message: "when the operative system and target environment are {name}"
}
condition! {
name: &target_cfg.abi,
allowed_names: &target_cfgs.all_abis,