Merge pull request #395 from eZioPan/forbid-multi-stm32-features

forbid enable multiple stm32 features ...
This commit is contained in:
Dario Nieuwenhuis 2024-02-19 12:40:09 +00:00 committed by GitHub
commit aaf4782498
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

View File

@ -2,18 +2,44 @@ use std::env;
#[cfg(any(feature = "rt", feature = "memory-x"))] #[cfg(any(feature = "rt", feature = "memory-x"))]
use std::path::PathBuf; use std::path::PathBuf;
enum GetOneError {
None,
Multiple,
}
trait IteratorExt: Iterator {
fn get_one(self) -> Result<Self::Item, GetOneError>;
}
impl<T: Iterator> IteratorExt for T {
fn get_one(mut self) -> Result<Self::Item, GetOneError> {
match self.next() {
None => Err(GetOneError::None),
Some(res) => match self.next() {
Some(_) => Err(GetOneError::Multiple),
None => Ok(res),
},
}
}
}
fn main() { fn main() {
#[cfg(any(feature = "rt", feature = "memory-x"))] #[cfg(any(feature = "rt", feature = "memory-x"))]
let crate_dir = PathBuf::from(env::var_os("CARGO_MANIFEST_DIR").unwrap()); let crate_dir = PathBuf::from(env::var_os("CARGO_MANIFEST_DIR").unwrap());
let chip_core_name = env::vars_os() let chip_core_name = match env::vars()
.map(|(a, _)| a.to_string_lossy().to_string()) .map(|(a, _)| a)
.find(|x| x.starts_with("CARGO_FEATURE_STM32")) .filter(|x| x.starts_with("CARGO_FEATURE_STM32"))
.expect("No stm32xx Cargo feature enabled") .get_one()
.strip_prefix("CARGO_FEATURE_") {
.unwrap() Ok(x) => x,
.to_ascii_lowercase() Err(GetOneError::None) => panic!("No stm32xx Cargo feature enabled"),
.replace('_', "-"); Err(GetOneError::Multiple) => panic!("Multiple stm32xx Cargo features enabled"),
}
.strip_prefix("CARGO_FEATURE_")
.unwrap()
.to_ascii_lowercase()
.replace('_', "-");
#[cfg(feature = "rt")] #[cfg(feature = "rt")]
println!( println!(