Struct serde_aux::field_attributes::StringOrVecToVec [−][src]
Builder to create a parser, that parses a separated string or a vec into a vec.
Example:
use serde_aux::prelude::*; use std::str::FromStr; fn parser<'de, D, T>(deserializer: D) -> Result<Vec<T>, D::Error> where D: serde::Deserializer<'de>, T: FromStr + serde::Deserialize<'de> + 'static, <T as FromStr>::Err: std::fmt::Display, { StringOrVecToVec::default().into_deserializer()(deserializer) } #[derive(serde::Serialize, serde::Deserialize, Debug)] struct MyStruct { #[serde(deserialize_with = "parser")] list: Vec<i32>, } let s = r#" { "list": "1,2,3,4" } "#; let a: MyStruct = serde_json::from_str(s).unwrap(); assert_eq!(&a.list, &[1, 2, 3, 4]); let s = r#" { "list": [1,2,3,4] } "#; let a: MyStruct = serde_json::from_str(s).unwrap(); assert_eq!(&a.list, &[1, 2, 3, 4]);
Implementations
impl<'a, 'de, T> StringOrVecToVec<'a, T, T::Err> where
T: FromStr + Deserialize<'de> + 'static,
<T as FromStr>::Err: Display,
[src]
T: FromStr + Deserialize<'de> + 'static,
<T as FromStr>::Err: Display,
pub fn with_separator(separator: impl Into<Pattern<'a>>) -> Self
[src]
Create a StringOrVecToVec
builder with a custom separator. T::from_str
is used to parse
the elements of the list.
Example:
use serde_aux::prelude::*; use std::str::FromStr; fn parser<'de, D, T>(deserializer: D) -> Result<Vec<T>, D::Error> where D: serde::Deserializer<'de>, T: FromStr + serde::Deserialize<'de> + 'static, <T as FromStr>::Err: std::fmt::Display, { StringOrVecToVec::with_separator(|c| c == '-' || c == '+').into_deserializer()(deserializer) } #[derive(serde::Serialize, serde::Deserialize, Debug)] struct MyStruct { #[serde(deserialize_with = "parser")] list: Vec<i32>, } let s = r#" { "list": "1-2+3-4" } "#; let a: MyStruct = serde_json::from_str(s).unwrap(); assert_eq!(&a.list, &[1, 2, 3, 4]); let s = r#" { "list": [1,2,3,4] } "#; let a: MyStruct = serde_json::from_str(s).unwrap(); assert_eq!(&a.list, &[1, 2, 3, 4]);
impl<'a, T, E> StringOrVecToVec<'a, T, E>
[src]
pub fn new(
separator: impl Into<Pattern<'a>>,
parser: impl FnMut(&str) -> Result<T, E> + 'static
) -> Self
[src]
separator: impl Into<Pattern<'a>>,
parser: impl FnMut(&str) -> Result<T, E> + 'static
) -> Self
Create a deserializer with a custom separator and parsing function.
Example:
use serde_aux::prelude::*; use std::str::FromStr; fn parser<'de, D, T>(deserializer: D) -> Result<Vec<T>, D::Error> where D: serde::Deserializer<'de>, T: FromStr + serde::Deserialize<'de> + 'static, <T as FromStr>::Err: std::fmt::Display, { StringOrVecToVec::new('-', |s| s.trim().parse()).into_deserializer()(deserializer) } #[derive(serde::Serialize, serde::Deserialize, Debug)] struct MyStruct { #[serde(deserialize_with = "parser")] list: Vec<i32>, } let s = r#" { "list": "1 - 2 - 3- 4 " } "#; let a: MyStruct = serde_json::from_str(s).unwrap(); assert_eq!(&a.list, &[1, 2, 3, 4]); let s = r#" { "list": [1,2,3,4] } "#; let a: MyStruct = serde_json::from_str(s).unwrap(); assert_eq!(&a.list, &[1, 2, 3, 4]);
pub fn with_parser(parser: impl FnMut(&str) -> Result<T, E> + 'static) -> Self
[src]
Create a deserializer with a custom parsing function. The input string will be separated on
,
.
Example:
use serde_aux::prelude::*; use std::str::FromStr; fn parser<'de, D, T>(deserializer: D) -> Result<Vec<T>, D::Error> where D: serde::Deserializer<'de>, T: FromStr + serde::Deserialize<'de> + 'static, <T as FromStr>::Err: std::fmt::Display, { StringOrVecToVec::with_parser(|s| s.trim().parse()).into_deserializer()(deserializer) } #[derive(serde::Serialize, serde::Deserialize, Debug)] struct MyStruct { #[serde(deserialize_with = "parser")] list: Vec<i32>, } let s = r#" { "list": "1 , 2 , 3, 4 " } "#; let a: MyStruct = serde_json::from_str(s).unwrap(); assert_eq!(&a.list, &[1, 2, 3, 4]); let s = r#" { "list": [1,2,3,4] } "#; let a: MyStruct = serde_json::from_str(s).unwrap(); assert_eq!(&a.list, &[1, 2, 3, 4]);
pub fn into_deserializer<'de, D>(
self
) -> impl FnMut(D) -> Result<Vec<T>, <D as Deserializer<'de>>::Error> where
'a: 'de,
D: Deserializer<'de>,
T: Deserialize<'de>,
E: Display,
[src]
self
) -> impl FnMut(D) -> Result<Vec<T>, <D as Deserializer<'de>>::Error> where
'a: 'de,
D: Deserializer<'de>,
T: Deserialize<'de>,
E: Display,
Creates the actual deserializer from this builder.
Trait Implementations
impl<'a, 'de, T> Default for StringOrVecToVec<'a, T, T::Err> where
T: FromStr + Deserialize<'de> + 'static,
<T as FromStr>::Err: Display,
[src]
T: FromStr + Deserialize<'de> + 'static,
<T as FromStr>::Err: Display,
Auto Trait Implementations
impl<'a, T, E> !RefUnwindSafe for StringOrVecToVec<'a, T, E>
impl<'a, T, E> !Send for StringOrVecToVec<'a, T, E>
impl<'a, T, E> !Sync for StringOrVecToVec<'a, T, E>
impl<'a, T, E> Unpin for StringOrVecToVec<'a, T, E>
impl<'a, T, E> !UnwindSafe for StringOrVecToVec<'a, T, E>
Blanket Implementations
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
pub fn borrow_mut(&mut self) -> &mut T
[src]
impl<T> From<T> for T
[src]
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
pub fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,