#[allow(missing_docs)] #[non_exhaustive]
#[derive(
std::clone::Clone,
std::cmp::Eq,
std::cmp::Ord,
std::cmp::PartialEq,
std::cmp::PartialOrd,
std::fmt::Debug,
std::hash::Hash,
)]
pub enum Statistic {
#[allow(missing_docs)] Average,
#[allow(missing_docs)] Maximum,
#[allow(missing_docs)] Minimum,
#[allow(missing_docs)] SampleCount,
#[allow(missing_docs)] Sum,
Unknown(crate::primitives::UnknownVariantValue),
}
impl std::convert::From<&str> for Statistic {
fn from(s: &str) -> Self {
match s {
"Average" => Statistic::Average,
"Maximum" => Statistic::Maximum,
"Minimum" => Statistic::Minimum,
"SampleCount" => Statistic::SampleCount,
"Sum" => Statistic::Sum,
other => Statistic::Unknown(crate::primitives::UnknownVariantValue(other.to_owned())),
}
}
}
impl std::str::FromStr for Statistic {
type Err = std::convert::Infallible;
fn from_str(s: &str) -> std::result::Result<Self, Self::Err> {
Ok(Statistic::from(s))
}
}
impl Statistic {
pub fn as_str(&self) -> &str {
match self {
Statistic::Average => "Average",
Statistic::Maximum => "Maximum",
Statistic::Minimum => "Minimum",
Statistic::SampleCount => "SampleCount",
Statistic::Sum => "Sum",
Statistic::Unknown(value) => value.as_str(),
}
}
pub const fn values() -> &'static [&'static str] {
&["Average", "Maximum", "Minimum", "SampleCount", "Sum"]
}
}
impl AsRef<str> for Statistic {
fn as_ref(&self) -> &str {
self.as_str()
}
}