#[allow(unused)]
macro_rules! features {
(
@TARGET: $target:ident;
@MACRO_NAME: $macro_name:ident;
@MACRO_ATTRS: $(#[$macro_attrs:meta])*
$(@BIND_FEATURE_NAME: $bind_feature:tt; $feature_impl:tt; )*
$(@NO_RUNTIME_DETECTION: $nort_feature:tt; )*
$(@FEATURE: $feature:ident: $feature_lit:tt; $(#[$feature_comment:meta])*)*
) => {
#[macro_export]
$(#[$macro_attrs])*
macro_rules! $macro_name {
$(
($feature_lit) => {
$crate::__is_feature_detected::$feature()
};
)*
$(
($bind_feature) => { $macro_name!($feature_impl); };
)*
$(
($nort_feature) => {
compile_error!(
concat!(
stringify!(nort_feature),
" feature cannot be detected at run-time"
)
)
};
)*
($t:tt,) => {
$macro_name!($t);
};
($t:tt) => {
compile_error!(
concat!(
concat!("unknown ", stringify!($target)),
concat!(" target feature: ", $t)
)
)
};
}
#[doc(hidden)]
#[allow(non_camel_case_types)]
#[derive(Copy, Clone)]
#[repr(u8)]
pub(crate) enum Feature {
$(
$(#[$feature_comment])*
$feature,
)*
_last
}
impl Feature {
pub(crate) fn to_str(self) -> &'static str {
match self {
$(Feature::$feature => $feature_lit,)*
Feature::_last => unreachable!(),
}
}
#[cfg(feature = "std_detect_env_override")]
pub(crate) fn from_str(s: &str) -> Result<Feature, ()> {
match s {
$($feature_lit => Ok(Feature::$feature),)*
_ => Err(())
}
}
}
#[doc(hidden)]
pub mod __is_feature_detected {
$(
#[inline]
#[doc(hidden)]
pub fn $feature() -> bool {
cfg!(target_feature = $feature_lit) ||
$crate::check_for($crate::Feature::$feature)
}
)*
}
};
}