mirror of
https://github.com/starship/starship.git
synced 2025-01-05 22:18:53 +01:00
implement deserialization from either a string or toml table
This commit is contained in:
parent
c1a0cefc30
commit
529ad751fe
@ -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"
|
||||||
})
|
}))
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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> {
|
||||||
|
Loading…
Reference in New Issue
Block a user