use crate::error::Error;
use serde::{de, ser, Deserialize, Serialize};
use std::{fmt, str::FromStr};
#[derive(Clone, Debug, Eq, Hash, PartialEq, PartialOrd, Ord)]
pub enum Informational {
Notice,
Unmaintained,
Other(String),
}
impl Informational {
pub fn as_str(&self) -> &str {
match self {
Informational::Notice => "notice",
Informational::Unmaintained => "unmaintained",
Informational::Other(other) => other,
}
}
}
impl fmt::Display for Informational {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
write!(f, "{}", self.as_str())
}
}
impl FromStr for Informational {
type Err = Error;
fn from_str(s: &str) -> Result<Self, Error> {
Ok(match s {
"notice" => Informational::Notice,
"unmaintained" => Informational::Unmaintained,
other => Informational::Other(other.to_owned()),
})
}
}
impl<'de> Deserialize<'de> for Informational {
fn deserialize<D: de::Deserializer<'de>>(deserializer: D) -> Result<Self, D::Error> {
use de::Error;
let string = String::deserialize(deserializer)?;
string.parse().map_err(D::Error::custom)
}
}
impl Serialize for Informational {
fn serialize<S: ser::Serializer>(&self, serializer: S) -> Result<S::Ok, S::Error> {
self.to_string().serialize(serializer)
}
}
#[cfg(test)]
mod tests {
use super::Informational;
#[test]
fn parse_notice() {
let notice = "notice".parse::<Informational>().unwrap();
assert_eq!(Informational::Notice, notice);
assert_eq!("notice", notice.as_str());
}
#[test]
fn parse_unmaintained() {
let unmaintained = "unmaintained".parse::<Informational>().unwrap();
assert_eq!(Informational::Unmaintained, unmaintained);
assert_eq!("unmaintained", unmaintained.as_str());
}
#[test]
fn parse_other() {
let other = "foobar".parse::<Informational>().unwrap();
assert_eq!(Informational::Other("foobar".to_owned()), other);
assert_eq!("foobar", other.as_str());
}
}