implement deserialization from either a string or toml table

This commit is contained in:
Filip Bachul 2022-04-06 00:08:27 +02:00
parent c1a0cefc30
commit 529ad751fe
2 changed files with 24 additions and 8 deletions

View File

@ -1,3 +1,4 @@
use crate::config::Either;
use crate::context::Context; use crate::context::Context;
use serde::{Deserialize, Deserializer, Serialize, Serializer}; use serde::{Deserialize, Deserializer, Serialize, Serializer};
@ -75,6 +76,21 @@ impl<'a> StarshipConditionalStyle<'a> {
} }
} }
#[derive(Clone, Debug, Default, Serialize, PartialEq)]
pub struct StarshipConditionalStyleConfig<'a>(pub StarshipConditionalStyle<'a>);
impl<'de: 'a, 'a> Deserialize<'de> for StarshipConditionalStyleConfig<'a> {
fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
where
D: Deserializer<'de>,
{
let either = Either::<StarshipConditionalStyle<'a>, &'a str>::deserialize(deserializer)?;
match either {
Either::First(v) => Ok(Self(v)),
Either::Second(s) => Ok(Self(StarshipConditionalStyle::from(s))),
}
}
}
pub fn get_conditional_style<'a>( pub fn get_conditional_style<'a>(
context: &Context, context: &Context,
items: &[StarshipConditionalStyle<'a>], items: &[StarshipConditionalStyle<'a>],
@ -138,16 +154,16 @@ mod tests {
let config = toml::value::Value::String(String::from("bold red dimmed")); let config = toml::value::Value::String(String::from("bold red dimmed"));
let deserializer = ValueDeserializer::new(&config); let deserializer = ValueDeserializer::new(&config);
let result = StarshipConditionalStyle::deserialize(deserializer); let result = StarshipConditionalStyleConfig::deserialize(deserializer);
assert_eq!( assert_eq!(
result, result,
Ok(StarshipConditionalStyle { Ok(StarshipConditionalStyleConfig(StarshipConditionalStyle {
env: None, env: None,
operator: None, operator: None,
expected_value: None, expected_value: None,
style: "bold dimmed red" style: "bold red dimmed"
}) }))
); );
} }
@ -161,16 +177,16 @@ mod tests {
}; };
let deserializer = ValueDeserializer::new(&config); let deserializer = ValueDeserializer::new(&config);
let result = StarshipConditionalStyle::deserialize(deserializer); let result = StarshipConditionalStyleConfig::deserialize(deserializer);
assert_eq!( assert_eq!(
result, result,
Ok(StarshipConditionalStyle { Ok(StarshipConditionalStyleConfig(StarshipConditionalStyle {
env: Some("HOSTNAME"), env: Some("HOSTNAME"),
operator: Some(StarshipConditionalStyleOperator::Equal), operator: Some(StarshipConditionalStyleOperator::Equal),
expected_value: Some("home"), expected_value: Some("home"),
style: "bold dimmed red" style: "bold dimmed red"
}) }))
); );
} }

View File

@ -49,7 +49,7 @@ impl<'a, T: Deserialize<'a> + Default> ModuleConfig<'a, ValueError> for T {
} }
} }
#[derive(Clone, Deserialize, Serialize)] #[derive(Clone, Debug, Deserialize, Serialize)]
#[cfg_attr(feature = "config-schema", derive(schemars::JsonSchema))] #[cfg_attr(feature = "config-schema", derive(schemars::JsonSchema))]
#[serde(untagged)] #[serde(untagged)]
pub enum Either<A, B> { pub enum Either<A, B> {