use serde::{de, Deserialize};
pub use trim_in_place::*;
pub fn string_trim<'de, D>(d: D) -> Result<String, D::Error>
where
D: de::Deserializer<'de>,
{
let mut de_string = String::deserialize(d)?;
de_string.trim_in_place();
Ok(de_string)
}
pub fn option_string_trim<'de, D>(d: D) -> Result<Option<String>, D::Error>
where
D: de::Deserializer<'de>,
{
let mut de_string: Option<String> = Option::deserialize(d)?;
if let Some(ref mut de_string) = de_string {
if de_string.trim_in_place().is_empty() {
return Ok(None);
}
}
Ok(de_string)
}
#[test]
fn test_string_trim() {
#[derive(Deserialize)]
struct Foo {
#[serde(deserialize_with = "string_trim")]
name: String,
}
let json = r#"{"name":" "}"#;
let foo = serde_json::from_str::<Foo>(json).unwrap();
assert_eq!(foo.name, "");
}
#[test]
fn test_option_string_trim() {
#[derive(Deserialize)]
struct OptionFoo {
#[serde(deserialize_with = "option_string_trim")]
name: Option<String>,
}
let json = r#"{"name":" "}"#;
let foo = serde_json::from_str::<OptionFoo>(json).unwrap();
assert_eq!(foo.name, None);
}