Merge pull request #168 from jondo2010/support_xst_lists
Support deserializing xst xs:list attributes as `Vec` types.
This commit is contained in:
		
						commit
						2426700211
					
				| @ -4,8 +4,10 @@ extern crate yaserde; | |||||||
| extern crate yaserde_derive; | extern crate yaserde_derive; | ||||||
| 
 | 
 | ||||||
| use log::debug; | use log::debug; | ||||||
|  | use std::default; | ||||||
| use std::io::Read; | use std::io::Read; | ||||||
| use yaserde::de::from_str; | use std::str::FromStr; | ||||||
|  | use yaserde::de::{self, from_str}; | ||||||
| use yaserde::YaDeserialize; | use yaserde::YaDeserialize; | ||||||
| 
 | 
 | ||||||
| fn init() { | fn init() { | ||||||
| @ -1050,3 +1052,37 @@ fn de_same_field_name_but_some_other_fields_or_something() { | |||||||
|   serialize_and_validate!(model, content); |   serialize_and_validate!(model, content); | ||||||
|   deserialize_and_validate!(content, model, FooOuter); |   deserialize_and_validate!(content, model, FooOuter); | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | #[test] | ||||||
|  | fn de_attribute_sequence() { | ||||||
|  |   init(); | ||||||
|  | 
 | ||||||
|  |   #[derive(Default, Debug, YaDeserialize, PartialEq)] | ||||||
|  |   pub enum Inner { | ||||||
|  |     #[default] | ||||||
|  |     #[yaserde(rename = "foo")] | ||||||
|  |     Foo, | ||||||
|  |     #[yaserde(rename = "bar")] | ||||||
|  |     Bar, | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   #[derive(Default, Debug, PartialEq, YaDeserialize)] | ||||||
|  |   pub struct Outer { | ||||||
|  |     #[yaserde(attribute, rename = "seq1")] | ||||||
|  |     seq1: Vec<i32>, | ||||||
|  |     #[yaserde(child, attribute, rename = "seq2")] | ||||||
|  |     seq2: Vec<Inner>, | ||||||
|  |     #[yaserde(attribute, rename = "seq3")] | ||||||
|  |     seq3: Vec<String>, | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   let content = r#"<Outer seq1="1 2 3 4" seq2="foo foo bar" seq3="one two" />"#; | ||||||
|  |   let model = Outer { | ||||||
|  |     seq1: vec![1, 2, 3, 4], | ||||||
|  |     seq2: vec![Inner::Foo, Inner::Foo, Inner::Bar], | ||||||
|  |     seq3: vec!["one".to_string(), "two".to_string()], | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   //serialize_and_validate!(model, content);
 | ||||||
|  |   deserialize_and_validate!(content, model, Outer); | ||||||
|  | } | ||||||
|  | |||||||
| @ -293,6 +293,7 @@ impl From<&Field> for String { | |||||||
|       Field::FieldU64 => "u64".to_string(), |       Field::FieldU64 => "u64".to_string(), | ||||||
|       Field::FieldF32 => "f32".to_string(), |       Field::FieldF32 => "f32".to_string(), | ||||||
|       Field::FieldF64 => "f64".to_string(), |       Field::FieldF64 => "f64".to_string(), | ||||||
|  |       Field::FieldStruct { struct_name } => quote!{#struct_name}.to_string(), | ||||||
|       _ => panic!("Not a simple type: {:?}", field), |       _ => panic!("Not a simple type: {:?}", field), | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|  | |||||||
| @ -38,7 +38,7 @@ pub fn parse( | |||||||
|           quote!(::std::vec![]), |           quote!(::std::vec![]), | ||||||
|         ), |         ), | ||||||
|         Field::FieldOption { .. } | Field::FieldVec { .. } => { |         Field::FieldOption { .. } | Field::FieldVec { .. } => { | ||||||
|           unimplemented!(); |           unimplemented!("Option or Vec nested in  Vec<>"); | ||||||
|         } |         } | ||||||
|         simple_type => { |         simple_type => { | ||||||
|           let type_token: TokenStream = simple_type.into(); |           let type_token: TokenStream = simple_type.into(); | ||||||
| @ -239,6 +239,20 @@ pub fn parse( | |||||||
|         }) |         }) | ||||||
|       }; |       }; | ||||||
| 
 | 
 | ||||||
|  |       let visit_vec = |action: &TokenStream, visitor: &Ident, visitor_label: &Ident| { | ||||||
|  |         Some(quote! { | ||||||
|  |           for attr in attributes { | ||||||
|  |             if attr.name.local_name == #label_name { | ||||||
|  |               for value in attr.value.split_whitespace() { | ||||||
|  |                 let visitor = #visitor_label{}; | ||||||
|  |                 let value = visitor.#visitor(value)?; | ||||||
|  |                 #label #action; | ||||||
|  |               } | ||||||
|  |             } | ||||||
|  |           } | ||||||
|  |         }) | ||||||
|  |       }; | ||||||
|  | 
 | ||||||
|       let visit_string = || { |       let visit_string = || { | ||||||
|         Some(quote! { |         Some(quote! { | ||||||
|           for attr in attributes { |           for attr in attributes { | ||||||
| @ -276,7 +290,19 @@ pub fn parse( | |||||||
|         Field::FieldOption { data_type } => { |         Field::FieldOption { data_type } => { | ||||||
|           visit_sub(data_type, quote! { = ::std::option::Option::Some(value) }) |           visit_sub(data_type, quote! { = ::std::option::Option::Some(value) }) | ||||||
|         } |         } | ||||||
|         Field::FieldVec { .. } => unimplemented!(), |         Field::FieldVec { data_type } => match data_type.as_ref() { | ||||||
|  |           Field::FieldStruct { struct_name } => visit_vec( | ||||||
|  |             "e! { .push(value) }, | ||||||
|  |             &Ident::new("visit_str", field.get_span()), | ||||||
|  |             &build_visitor_ident(&label_name, field.get_span(), Some(&struct_name)), | ||||||
|  |           ), | ||||||
|  |           Field::FieldOption { .. } | Field::FieldVec { .. } => unimplemented!("Not supported"), | ||||||
|  |           simple_type => visit_vec( | ||||||
|  |             "e! { .push(value) }, | ||||||
|  |             &simple_type.get_simple_type_visitor(), | ||||||
|  |             &visitor_label, | ||||||
|  |           ), | ||||||
|  |         }, | ||||||
|         Field::FieldStruct { struct_name } => visit_struct(struct_name, quote! { = value }), |         Field::FieldStruct { struct_name } => visit_struct(struct_name, quote! { = value }), | ||||||
|         simple_type => visit_simple(simple_type, quote! { = value }), |         simple_type => visit_simple(simple_type, quote! { = value }), | ||||||
|       } |       } | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user