remove clippy messages to clean code
This commit is contained in:
		
							parent
							
								
									d63e9d27d8
								
							
						
					
					
						commit
						c87d0faa02
					
				| @ -26,7 +26,7 @@ fn get_value(iter: &mut TokenTreeIter) -> Option<String> { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| impl YaSerdeAttribute { | impl YaSerdeAttribute { | ||||||
|   pub fn parse(attrs: &Vec<Attribute>) -> YaSerdeAttribute { |   pub fn parse(attrs: &[Attribute]) -> YaSerdeAttribute { | ||||||
|     let mut attribute = false; |     let mut attribute = false; | ||||||
|     let mut namespaces = BTreeMap::new(); |     let mut namespaces = BTreeMap::new(); | ||||||
|     let mut prefix = None; |     let mut prefix = None; | ||||||
| @ -36,59 +36,54 @@ impl YaSerdeAttribute { | |||||||
| 
 | 
 | ||||||
|     for attr in attrs.iter() { |     for attr in attrs.iter() { | ||||||
|       let mut attr_iter = attr.clone().tts.into_iter(); |       let mut attr_iter = attr.clone().tts.into_iter(); | ||||||
|       match attr_iter.next() { |       if let Some(token) = attr_iter.next() { | ||||||
|         Some(token) => match token.kind { |         if let Group(Parenthesis, token_stream) = token.kind { | ||||||
|           Group(Parenthesis, token_stream) => { |           let mut attr_iter = token_stream.into_iter(); | ||||||
|             let mut attr_iter = token_stream.into_iter(); |  | ||||||
| 
 | 
 | ||||||
|             while let Some(item) = attr_iter.next() { |           while let Some(item) = attr_iter.next() { | ||||||
|               match item.kind { |             if let Term(term) = item.kind { | ||||||
|                 Term(t) => match t.as_str() { |               match term.as_str() { | ||||||
|                   "attribute" => { |                 "attribute" => { | ||||||
|                     attribute = true; |                   attribute = true; | ||||||
|                   } |                 } | ||||||
|                   "namespace" => { |                 "namespace" => { | ||||||
|                     if let Some(namespace) = get_value(&mut attr_iter) { |                   if let Some(namespace) = get_value(&mut attr_iter) { | ||||||
|                       let splitted: Vec<&str> = namespace.split(": ").collect(); |                     let splitted: Vec<&str> = namespace.split(": ").collect(); | ||||||
|                       if splitted.len() == 2 { |                     if splitted.len() == 2 { | ||||||
|                         namespaces.insert(splitted[0].to_owned(), splitted[1].to_owned()); |                       namespaces.insert(splitted[0].to_owned(), splitted[1].to_owned()); | ||||||
|                       } |                     } | ||||||
|                       if splitted.len() == 1 { |                     if splitted.len() == 1 { | ||||||
|                         namespaces.insert("".to_owned(), splitted[0].to_owned()); |                       namespaces.insert("".to_owned(), splitted[0].to_owned()); | ||||||
|                       } |  | ||||||
|                     } |                     } | ||||||
|                   } |                   } | ||||||
|                   "prefix" => { |                 } | ||||||
|                     prefix = get_value(&mut attr_iter); |                 "prefix" => { | ||||||
|                   } |                   prefix = get_value(&mut attr_iter); | ||||||
|                   "rename" => { |                 } | ||||||
|                     rename = get_value(&mut attr_iter); |                 "rename" => { | ||||||
|                   } |                   rename = get_value(&mut attr_iter); | ||||||
|                   "root" => { |                 } | ||||||
|                     root = get_value(&mut attr_iter); |                 "root" => { | ||||||
|                   } |                   root = get_value(&mut attr_iter); | ||||||
|                   "text" => { |                 } | ||||||
|                     text = true; |                 "text" => { | ||||||
|                   } |                   text = true; | ||||||
|                   _ => {} |                 } | ||||||
|                 }, |  | ||||||
|                 _ => {} |                 _ => {} | ||||||
|               } |               } | ||||||
|             } |             } | ||||||
|           } |           } | ||||||
|           _ => {} |         } | ||||||
|         }, |  | ||||||
|         None => {} |  | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     YaSerdeAttribute { |     YaSerdeAttribute { | ||||||
|       attribute: attribute, |       attribute, | ||||||
|       namespaces: namespaces, |       namespaces, | ||||||
|       prefix: prefix, |       prefix, | ||||||
|       rename: rename, |       rename, | ||||||
|       root: root, |       root, | ||||||
|       text: text, |       text, | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  | |||||||
| @ -10,7 +10,7 @@ use proc_macro2::Span; | |||||||
| pub fn parse( | pub fn parse( | ||||||
|   data_enum: &DataEnum, |   data_enum: &DataEnum, | ||||||
|   name: &Ident, |   name: &Ident, | ||||||
|   root: &String, |   root: &str, | ||||||
|   _namespaces: &BTreeMap<String, String>, |   _namespaces: &BTreeMap<String, String>, | ||||||
| ) -> Tokens { | ) -> Tokens { | ||||||
|   let variables: Tokens = data_enum |   let variables: Tokens = data_enum | ||||||
| @ -27,34 +27,34 @@ pub fn parse( | |||||||
| 
 | 
 | ||||||
|             match get_field_type(field) { |             match get_field_type(field) { | ||||||
|               Some(FieldType::FieldTypeString) => { |               Some(FieldType::FieldTypeString) => { | ||||||
|                 build_default_value(&field_label, quote!{String}, quote!{"".to_string()}) |                 build_default_value(&field_label, "e!{String}, "e!{"".to_string()}) | ||||||
|               } |               } | ||||||
|               Some(FieldType::FieldTypeBool) => { |               Some(FieldType::FieldTypeBool) => { | ||||||
|                 build_default_value(&field_label, quote!{bool}, quote!{false}) |                 build_default_value(&field_label, "e!{bool}, "e!{false}) | ||||||
|               } |               } | ||||||
|               Some(FieldType::FieldTypeI8) => { |               Some(FieldType::FieldTypeI8) => { | ||||||
|                 build_default_value(&field_label, quote!{i8}, quote!{0}) |                 build_default_value(&field_label, "e!{i8}, "e!{0}) | ||||||
|               } |               } | ||||||
|               Some(FieldType::FieldTypeU8) => { |               Some(FieldType::FieldTypeU8) => { | ||||||
|                 build_default_value(&field_label, quote!{u8}, quote!{0}) |                 build_default_value(&field_label, "e!{u8}, "e!{0}) | ||||||
|               } |               } | ||||||
|               Some(FieldType::FieldTypeI16) => { |               Some(FieldType::FieldTypeI16) => { | ||||||
|                 build_default_value(&field_label, quote!{i16}, quote!{0}) |                 build_default_value(&field_label, "e!{i16}, "e!{0}) | ||||||
|               } |               } | ||||||
|               Some(FieldType::FieldTypeU16) => { |               Some(FieldType::FieldTypeU16) => { | ||||||
|                 build_default_value(&field_label, quote!{u16}, quote!{0}) |                 build_default_value(&field_label, "e!{u16}, "e!{0}) | ||||||
|               } |               } | ||||||
|               Some(FieldType::FieldTypeI32) => { |               Some(FieldType::FieldTypeI32) => { | ||||||
|                 build_default_value(&field_label, quote!{i32}, quote!{0}) |                 build_default_value(&field_label, "e!{i32}, "e!{0}) | ||||||
|               } |               } | ||||||
|               Some(FieldType::FieldTypeU32) => { |               Some(FieldType::FieldTypeU32) => { | ||||||
|                 build_default_value(&field_label, quote!{u32}, quote!{0}) |                 build_default_value(&field_label, "e!{u32}, "e!{0}) | ||||||
|               } |               } | ||||||
|               Some(FieldType::FieldTypeI64) => { |               Some(FieldType::FieldTypeI64) => { | ||||||
|                 build_default_value(&field_label, quote!{i64}, quote!{0}) |                 build_default_value(&field_label, "e!{i64}, "e!{0}) | ||||||
|               } |               } | ||||||
|               Some(FieldType::FieldTypeU64) => { |               Some(FieldType::FieldTypeU64) => { | ||||||
|                 build_default_value(&field_label, quote!{u64}, quote!{0}) |                 build_default_value(&field_label, "e!{u64}, "e!{0}) | ||||||
|               } |               } | ||||||
|               Some(FieldType::FieldTypeStruct { struct_name }) => Some(quote!{ |               Some(FieldType::FieldTypeStruct { struct_name }) => Some(quote!{ | ||||||
|                 #[allow(unused_mut)] |                 #[allow(unused_mut)] | ||||||
| @ -64,34 +64,34 @@ pub fn parse( | |||||||
|                 let dt = Box::into_raw(data_type); |                 let dt = Box::into_raw(data_type); | ||||||
|                 match unsafe { dt.as_ref() } { |                 match unsafe { dt.as_ref() } { | ||||||
|                   Some(&FieldType::FieldTypeString) => { |                   Some(&FieldType::FieldTypeString) => { | ||||||
|                     build_default_value(&field_label, quote!{Vec<String>}, quote!{vec![]}) |                     build_default_value(&field_label, "e!{Vec<String>}, "e!{vec![]}) | ||||||
|                   } |                   } | ||||||
|                   Some(&FieldType::FieldTypeBool) => { |                   Some(&FieldType::FieldTypeBool) => { | ||||||
|                     build_default_value(&field_label, quote!{Vec<bool>}, quote!{vec![]}) |                     build_default_value(&field_label, "e!{Vec<bool>}, "e!{vec![]}) | ||||||
|                   } |                   } | ||||||
|                   Some(&FieldType::FieldTypeI8) => { |                   Some(&FieldType::FieldTypeI8) => { | ||||||
|                     build_default_value(&field_label, quote!{Vec<i8>}, quote!{vec![]}) |                     build_default_value(&field_label, "e!{Vec<i8>}, "e!{vec![]}) | ||||||
|                   } |                   } | ||||||
|                   Some(&FieldType::FieldTypeU8) => { |                   Some(&FieldType::FieldTypeU8) => { | ||||||
|                     build_default_value(&field_label, quote!{Vec<u8>}, quote!{vec![]}) |                     build_default_value(&field_label, "e!{Vec<u8>}, "e!{vec![]}) | ||||||
|                   } |                   } | ||||||
|                   Some(&FieldType::FieldTypeI16) => { |                   Some(&FieldType::FieldTypeI16) => { | ||||||
|                     build_default_value(&field_label, quote!{Vec<i16>}, quote!{vec![]}) |                     build_default_value(&field_label, "e!{Vec<i16>}, "e!{vec![]}) | ||||||
|                   } |                   } | ||||||
|                   Some(&FieldType::FieldTypeU16) => { |                   Some(&FieldType::FieldTypeU16) => { | ||||||
|                     build_default_value(&field_label, quote!{Vec<u16>}, quote!{vec![]}) |                     build_default_value(&field_label, "e!{Vec<u16>}, "e!{vec![]}) | ||||||
|                   } |                   } | ||||||
|                   Some(&FieldType::FieldTypeI32) => { |                   Some(&FieldType::FieldTypeI32) => { | ||||||
|                     build_default_value(&field_label, quote!{Vec<i32>}, quote!{vec![]}) |                     build_default_value(&field_label, "e!{Vec<i32>}, "e!{vec![]}) | ||||||
|                   } |                   } | ||||||
|                   Some(&FieldType::FieldTypeU32) => { |                   Some(&FieldType::FieldTypeU32) => { | ||||||
|                     build_default_value(&field_label, quote!{Vec<u32>}, quote!{vec![]}) |                     build_default_value(&field_label, "e!{Vec<u32>}, "e!{vec![]}) | ||||||
|                   } |                   } | ||||||
|                   Some(&FieldType::FieldTypeI64) => { |                   Some(&FieldType::FieldTypeI64) => { | ||||||
|                     build_default_value(&field_label, quote!{Vec<i64>}, quote!{vec![]}) |                     build_default_value(&field_label, "e!{Vec<i64>}, "e!{vec![]}) | ||||||
|                   } |                   } | ||||||
|                   Some(&FieldType::FieldTypeU64) => { |                   Some(&FieldType::FieldTypeU64) => { | ||||||
|                     build_default_value(&field_label, quote!{Vec<u64>}, quote!{vec![]}) |                     build_default_value(&field_label, "e!{Vec<u64>}, "e!{vec![]}) | ||||||
|                   } |                   } | ||||||
|                   Some(&FieldType::FieldTypeStruct { struct_name }) => Some(quote!{ |                   Some(&FieldType::FieldTypeStruct { struct_name }) => Some(quote!{ | ||||||
|                     #[allow(unused_mut)] |                     #[allow(unused_mut)] | ||||||
| @ -274,8 +274,8 @@ pub fn parse( | |||||||
| 
 | 
 | ||||||
| fn build_default_value( | fn build_default_value( | ||||||
|   label: &Option<Ident>, |   label: &Option<Ident>, | ||||||
|   field_type: Tokens, |   field_type: &Tokens, | ||||||
|   default: Tokens, |   default: &Tokens, | ||||||
| ) -> Option<Tokens> { | ) -> Option<Tokens> { | ||||||
|   Some(quote!{ |   Some(quote!{ | ||||||
|     #[allow(unused_mut)] |     #[allow(unused_mut)] | ||||||
|  | |||||||
| @ -9,7 +9,7 @@ use proc_macro2::Span; | |||||||
| pub fn parse( | pub fn parse( | ||||||
|   data_struct: &DataStruct, |   data_struct: &DataStruct, | ||||||
|   name: &Ident, |   name: &Ident, | ||||||
|   root: &String, |   root: &str, | ||||||
|   namespaces: &BTreeMap<String, String>, |   namespaces: &BTreeMap<String, String>, | ||||||
| ) -> Tokens { | ) -> Tokens { | ||||||
|   let validate_namespace: Tokens = namespaces |   let validate_namespace: Tokens = namespaces | ||||||
| @ -43,17 +43,19 @@ pub fn parse( | |||||||
|       let label = field.ident; |       let label = field.ident; | ||||||
|       match get_field_type(field) { |       match get_field_type(field) { | ||||||
|         Some(FieldType::FieldTypeString) => { |         Some(FieldType::FieldTypeString) => { | ||||||
|           build_default_value(&label, quote!{String}, quote!{"".to_string()}) |           build_default_value(&label, "e!{String}, "e!{"".to_string()}) | ||||||
|         } |         } | ||||||
|         Some(FieldType::FieldTypeBool) => build_default_value(&label, quote!{bool}, quote!{false}), |         Some(FieldType::FieldTypeBool) => { | ||||||
|         Some(FieldType::FieldTypeI8) => build_default_value(&label, quote!{i8}, quote!{0}), |           build_default_value(&label, "e!{bool}, "e!{false}) | ||||||
|         Some(FieldType::FieldTypeU8) => build_default_value(&label, quote!{u8}, quote!{0}), |         } | ||||||
|         Some(FieldType::FieldTypeI16) => build_default_value(&label, quote!{i16}, quote!{0}), |         Some(FieldType::FieldTypeI8) => build_default_value(&label, "e!{i8}, "e!{0}), | ||||||
|         Some(FieldType::FieldTypeU16) => build_default_value(&label, quote!{u16}, quote!{0}), |         Some(FieldType::FieldTypeU8) => build_default_value(&label, "e!{u8}, "e!{0}), | ||||||
|         Some(FieldType::FieldTypeI32) => build_default_value(&label, quote!{i32}, quote!{0}), |         Some(FieldType::FieldTypeI16) => build_default_value(&label, "e!{i16}, "e!{0}), | ||||||
|         Some(FieldType::FieldTypeU32) => build_default_value(&label, quote!{u32}, quote!{0}), |         Some(FieldType::FieldTypeU16) => build_default_value(&label, "e!{u16}, "e!{0}), | ||||||
|         Some(FieldType::FieldTypeI64) => build_default_value(&label, quote!{i64}, quote!{0}), |         Some(FieldType::FieldTypeI32) => build_default_value(&label, "e!{i32}, "e!{0}), | ||||||
|         Some(FieldType::FieldTypeU64) => build_default_value(&label, quote!{u64}, quote!{0}), |         Some(FieldType::FieldTypeU32) => build_default_value(&label, "e!{u32}, "e!{0}), | ||||||
|  |         Some(FieldType::FieldTypeI64) => build_default_value(&label, "e!{i64}, "e!{0}), | ||||||
|  |         Some(FieldType::FieldTypeU64) => build_default_value(&label, "e!{u64}, "e!{0}), | ||||||
|         Some(FieldType::FieldTypeStruct { struct_name }) => Some(quote!{ |         Some(FieldType::FieldTypeStruct { struct_name }) => Some(quote!{ | ||||||
|           #[allow(unused_mut, non_snake_case, non_camel_case_types)] |           #[allow(unused_mut, non_snake_case, non_camel_case_types)] | ||||||
|           let mut #label : #struct_name = #struct_name::default(); |           let mut #label : #struct_name = #struct_name::default(); | ||||||
| @ -62,34 +64,34 @@ pub fn parse( | |||||||
|           let dt = Box::into_raw(data_type); |           let dt = Box::into_raw(data_type); | ||||||
|           match unsafe { dt.as_ref() } { |           match unsafe { dt.as_ref() } { | ||||||
|             Some(&FieldType::FieldTypeString) => { |             Some(&FieldType::FieldTypeString) => { | ||||||
|               build_default_value(&label, quote!{Vec<String>}, quote!{vec![]}) |               build_default_value(&label, "e!{Vec<String>}, "e!{vec![]}) | ||||||
|             } |             } | ||||||
|             Some(&FieldType::FieldTypeBool) => { |             Some(&FieldType::FieldTypeBool) => { | ||||||
|               build_default_value(&label, quote!{Vec<bool>}, quote!{vec![]}) |               build_default_value(&label, "e!{Vec<bool>}, "e!{vec![]}) | ||||||
|             } |             } | ||||||
|             Some(&FieldType::FieldTypeI8) => { |             Some(&FieldType::FieldTypeI8) => { | ||||||
|               build_default_value(&label, quote!{Vec<i8>}, quote!{vec![]}) |               build_default_value(&label, "e!{Vec<i8>}, "e!{vec![]}) | ||||||
|             } |             } | ||||||
|             Some(&FieldType::FieldTypeU8) => { |             Some(&FieldType::FieldTypeU8) => { | ||||||
|               build_default_value(&label, quote!{Vec<u8>}, quote!{vec![]}) |               build_default_value(&label, "e!{Vec<u8>}, "e!{vec![]}) | ||||||
|             } |             } | ||||||
|             Some(&FieldType::FieldTypeI16) => { |             Some(&FieldType::FieldTypeI16) => { | ||||||
|               build_default_value(&label, quote!{Vec<i16>}, quote!{vec![]}) |               build_default_value(&label, "e!{Vec<i16>}, "e!{vec![]}) | ||||||
|             } |             } | ||||||
|             Some(&FieldType::FieldTypeU16) => { |             Some(&FieldType::FieldTypeU16) => { | ||||||
|               build_default_value(&label, quote!{Vec<u16>}, quote!{vec![]}) |               build_default_value(&label, "e!{Vec<u16>}, "e!{vec![]}) | ||||||
|             } |             } | ||||||
|             Some(&FieldType::FieldTypeI32) => { |             Some(&FieldType::FieldTypeI32) => { | ||||||
|               build_default_value(&label, quote!{Vec<i32>}, quote!{vec![]}) |               build_default_value(&label, "e!{Vec<i32>}, "e!{vec![]}) | ||||||
|             } |             } | ||||||
|             Some(&FieldType::FieldTypeU32) => { |             Some(&FieldType::FieldTypeU32) => { | ||||||
|               build_default_value(&label, quote!{Vec<u32>}, quote!{vec![]}) |               build_default_value(&label, "e!{Vec<u32>}, "e!{vec![]}) | ||||||
|             } |             } | ||||||
|             Some(&FieldType::FieldTypeI64) => { |             Some(&FieldType::FieldTypeI64) => { | ||||||
|               build_default_value(&label, quote!{Vec<i64>}, quote!{vec![]}) |               build_default_value(&label, "e!{Vec<i64>}, "e!{vec![]}) | ||||||
|             } |             } | ||||||
|             Some(&FieldType::FieldTypeU64) => { |             Some(&FieldType::FieldTypeU64) => { | ||||||
|               build_default_value(&label, quote!{Vec<u64>}, quote!{vec![]}) |               build_default_value(&label, "e!{Vec<u64>}, "e!{vec![]}) | ||||||
|             } |             } | ||||||
|             Some(&FieldType::FieldTypeStruct { struct_name }) => Some(quote!{ |             Some(&FieldType::FieldTypeStruct { struct_name }) => Some(quote!{ | ||||||
|               #[allow(unused_mut)] |               #[allow(unused_mut)] | ||||||
| @ -129,43 +131,43 @@ pub fn parse( | |||||||
|       match get_field_type(field) { |       match get_field_type(field) { | ||||||
|         Some(FieldType::FieldTypeString) => { |         Some(FieldType::FieldTypeString) => { | ||||||
|           let visitor = Ident::new("visit_str", Span::call_site()); |           let visitor = Ident::new("visit_str", Span::call_site()); | ||||||
|           build_declare_visitor(quote!{String}, &visitor, &visitor_label) |           build_declare_visitor("e!{String}, &visitor, &visitor_label) | ||||||
|         } |         } | ||||||
|         Some(FieldType::FieldTypeBool) => { |         Some(FieldType::FieldTypeBool) => { | ||||||
|           let visitor = Ident::new("visit_bool", Span::call_site()); |           let visitor = Ident::new("visit_bool", Span::call_site()); | ||||||
|           build_declare_visitor(quote!{bool}, &visitor, &visitor_label) |           build_declare_visitor("e!{bool}, &visitor, &visitor_label) | ||||||
|         } |         } | ||||||
|         Some(FieldType::FieldTypeI8) => { |         Some(FieldType::FieldTypeI8) => { | ||||||
|           let visitor = Ident::new("visit_i8", Span::call_site()); |           let visitor = Ident::new("visit_i8", Span::call_site()); | ||||||
|           build_declare_visitor(quote!{i8}, &visitor, &visitor_label) |           build_declare_visitor("e!{i8}, &visitor, &visitor_label) | ||||||
|         } |         } | ||||||
|         Some(FieldType::FieldTypeU8) => { |         Some(FieldType::FieldTypeU8) => { | ||||||
|           let visitor = Ident::new("visit_u8", Span::call_site()); |           let visitor = Ident::new("visit_u8", Span::call_site()); | ||||||
|           build_declare_visitor(quote!{u8}, &visitor, &visitor_label) |           build_declare_visitor("e!{u8}, &visitor, &visitor_label) | ||||||
|         } |         } | ||||||
|         Some(FieldType::FieldTypeI16) => { |         Some(FieldType::FieldTypeI16) => { | ||||||
|           let visitor = Ident::new("visit_i16", Span::call_site()); |           let visitor = Ident::new("visit_i16", Span::call_site()); | ||||||
|           build_declare_visitor(quote!{i16}, &visitor, &visitor_label) |           build_declare_visitor("e!{i16}, &visitor, &visitor_label) | ||||||
|         } |         } | ||||||
|         Some(FieldType::FieldTypeU16) => { |         Some(FieldType::FieldTypeU16) => { | ||||||
|           let visitor = Ident::new("visit_u16", Span::call_site()); |           let visitor = Ident::new("visit_u16", Span::call_site()); | ||||||
|           build_declare_visitor(quote!{u16}, &visitor, &visitor_label) |           build_declare_visitor("e!{u16}, &visitor, &visitor_label) | ||||||
|         } |         } | ||||||
|         Some(FieldType::FieldTypeI32) => { |         Some(FieldType::FieldTypeI32) => { | ||||||
|           let visitor = Ident::new("visit_i32", Span::call_site()); |           let visitor = Ident::new("visit_i32", Span::call_site()); | ||||||
|           build_declare_visitor(quote!{i32}, &visitor, &visitor_label) |           build_declare_visitor("e!{i32}, &visitor, &visitor_label) | ||||||
|         } |         } | ||||||
|         Some(FieldType::FieldTypeU32) => { |         Some(FieldType::FieldTypeU32) => { | ||||||
|           let visitor = Ident::new("visit_u32", Span::call_site()); |           let visitor = Ident::new("visit_u32", Span::call_site()); | ||||||
|           build_declare_visitor(quote!{u32}, &visitor, &visitor_label) |           build_declare_visitor("e!{u32}, &visitor, &visitor_label) | ||||||
|         } |         } | ||||||
|         Some(FieldType::FieldTypeI64) => { |         Some(FieldType::FieldTypeI64) => { | ||||||
|           let visitor = Ident::new("visit_i64", Span::call_site()); |           let visitor = Ident::new("visit_i64", Span::call_site()); | ||||||
|           build_declare_visitor(quote!{i64}, &visitor, &visitor_label) |           build_declare_visitor("e!{i64}, &visitor, &visitor_label) | ||||||
|         } |         } | ||||||
|         Some(FieldType::FieldTypeU64) => { |         Some(FieldType::FieldTypeU64) => { | ||||||
|           let visitor = Ident::new("visit_u64", Span::call_site()); |           let visitor = Ident::new("visit_u64", Span::call_site()); | ||||||
|           build_declare_visitor(quote!{u64}, &visitor, &visitor_label) |           build_declare_visitor("e!{u64}, &visitor, &visitor_label) | ||||||
|         } |         } | ||||||
|         Some(FieldType::FieldTypeStruct { struct_name }) => { |         Some(FieldType::FieldTypeStruct { struct_name }) => { | ||||||
|           let struct_id = struct_name.to_string(); |           let struct_id = struct_name.to_string(); | ||||||
| @ -193,43 +195,43 @@ pub fn parse( | |||||||
|           match unsafe { dt.as_ref() } { |           match unsafe { dt.as_ref() } { | ||||||
|             Some(&FieldType::FieldTypeString) => { |             Some(&FieldType::FieldTypeString) => { | ||||||
|               let visitor = Ident::new("visit_str", Span::call_site()); |               let visitor = Ident::new("visit_str", Span::call_site()); | ||||||
|               build_declare_visitor(quote!{String}, &visitor, &visitor_label) |               build_declare_visitor("e!{String}, &visitor, &visitor_label) | ||||||
|             } |             } | ||||||
|             Some(&FieldType::FieldTypeBool) => { |             Some(&FieldType::FieldTypeBool) => { | ||||||
|               let visitor = Ident::new("visit_bool", Span::call_site()); |               let visitor = Ident::new("visit_bool", Span::call_site()); | ||||||
|               build_declare_visitor(quote!{bool}, &visitor, &visitor_label) |               build_declare_visitor("e!{bool}, &visitor, &visitor_label) | ||||||
|             } |             } | ||||||
|             Some(&FieldType::FieldTypeI8) => { |             Some(&FieldType::FieldTypeI8) => { | ||||||
|               let visitor = Ident::new("visit_i8", Span::call_site()); |               let visitor = Ident::new("visit_i8", Span::call_site()); | ||||||
|               build_declare_visitor(quote!{i8}, &visitor, &visitor_label) |               build_declare_visitor("e!{i8}, &visitor, &visitor_label) | ||||||
|             } |             } | ||||||
|             Some(&FieldType::FieldTypeU8) => { |             Some(&FieldType::FieldTypeU8) => { | ||||||
|               let visitor = Ident::new("visit_u8", Span::call_site()); |               let visitor = Ident::new("visit_u8", Span::call_site()); | ||||||
|               build_declare_visitor(quote!{u8}, &visitor, &visitor_label) |               build_declare_visitor("e!{u8}, &visitor, &visitor_label) | ||||||
|             } |             } | ||||||
|             Some(&FieldType::FieldTypeI16) => { |             Some(&FieldType::FieldTypeI16) => { | ||||||
|               let visitor = Ident::new("visit_i16", Span::call_site()); |               let visitor = Ident::new("visit_i16", Span::call_site()); | ||||||
|               build_declare_visitor(quote!{i16}, &visitor, &visitor_label) |               build_declare_visitor("e!{i16}, &visitor, &visitor_label) | ||||||
|             } |             } | ||||||
|             Some(&FieldType::FieldTypeU16) => { |             Some(&FieldType::FieldTypeU16) => { | ||||||
|               let visitor = Ident::new("visit_u16", Span::call_site()); |               let visitor = Ident::new("visit_u16", Span::call_site()); | ||||||
|               build_declare_visitor(quote!{u16}, &visitor, &visitor_label) |               build_declare_visitor("e!{u16}, &visitor, &visitor_label) | ||||||
|             } |             } | ||||||
|             Some(&FieldType::FieldTypeI32) => { |             Some(&FieldType::FieldTypeI32) => { | ||||||
|               let visitor = Ident::new("visit_i32", Span::call_site()); |               let visitor = Ident::new("visit_i32", Span::call_site()); | ||||||
|               build_declare_visitor(quote!{i32}, &visitor, &visitor_label) |               build_declare_visitor("e!{i32}, &visitor, &visitor_label) | ||||||
|             } |             } | ||||||
|             Some(&FieldType::FieldTypeU32) => { |             Some(&FieldType::FieldTypeU32) => { | ||||||
|               let visitor = Ident::new("visit_u32", Span::call_site()); |               let visitor = Ident::new("visit_u32", Span::call_site()); | ||||||
|               build_declare_visitor(quote!{u32}, &visitor, &visitor_label) |               build_declare_visitor("e!{u32}, &visitor, &visitor_label) | ||||||
|             } |             } | ||||||
|             Some(&FieldType::FieldTypeI64) => { |             Some(&FieldType::FieldTypeI64) => { | ||||||
|               let visitor = Ident::new("visit_i64", Span::call_site()); |               let visitor = Ident::new("visit_i64", Span::call_site()); | ||||||
|               build_declare_visitor(quote!{i64}, &visitor, &visitor_label) |               build_declare_visitor("e!{i64}, &visitor, &visitor_label) | ||||||
|             } |             } | ||||||
|             Some(&FieldType::FieldTypeU64) => { |             Some(&FieldType::FieldTypeU64) => { | ||||||
|               let visitor = Ident::new("visit_u64", Span::call_site()); |               let visitor = Ident::new("visit_u64", Span::call_site()); | ||||||
|               build_declare_visitor(quote!{u64}, &visitor, &visitor_label) |               build_declare_visitor("e!{u64}, &visitor, &visitor_label) | ||||||
|             } |             } | ||||||
|             Some(&FieldType::FieldTypeStruct { struct_name }) => { |             Some(&FieldType::FieldTypeStruct { struct_name }) => { | ||||||
|               let struct_ident = Ident::new(&format!("{}", struct_name), Span::def_site()); |               let struct_ident = Ident::new(&format!("{}", struct_name), Span::def_site()); | ||||||
| @ -277,9 +279,9 @@ pub fn parse( | |||||||
|         Some(FieldType::FieldTypeString) => { |         Some(FieldType::FieldTypeString) => { | ||||||
|           let visitor = Ident::new("visit_str", Span::call_site()); |           let visitor = Ident::new("visit_str", Span::call_site()); | ||||||
|           build_call_visitor( |           build_call_visitor( | ||||||
|             quote!{String}, |             "e!{String}, | ||||||
|             &visitor, |             &visitor, | ||||||
|             quote!{= value}, |             "e!{= value}, | ||||||
|             &visitor_label, |             &visitor_label, | ||||||
|             &label, |             &label, | ||||||
|             &label_name, |             &label_name, | ||||||
| @ -288,9 +290,9 @@ pub fn parse( | |||||||
|         Some(FieldType::FieldTypeBool) => { |         Some(FieldType::FieldTypeBool) => { | ||||||
|           let visitor = Ident::new("visit_bool", Span::call_site()); |           let visitor = Ident::new("visit_bool", Span::call_site()); | ||||||
|           build_call_visitor( |           build_call_visitor( | ||||||
|             quote!{bool}, |             "e!{bool}, | ||||||
|             &visitor, |             &visitor, | ||||||
|             quote!{= value}, |             "e!{= value}, | ||||||
|             &visitor_label, |             &visitor_label, | ||||||
|             &label, |             &label, | ||||||
|             &label_name, |             &label_name, | ||||||
| @ -299,9 +301,9 @@ pub fn parse( | |||||||
|         Some(FieldType::FieldTypeI8) => { |         Some(FieldType::FieldTypeI8) => { | ||||||
|           let visitor = Ident::new("visit_i8", Span::call_site()); |           let visitor = Ident::new("visit_i8", Span::call_site()); | ||||||
|           build_call_visitor( |           build_call_visitor( | ||||||
|             quote!{i8}, |             "e!{i8}, | ||||||
|             &visitor, |             &visitor, | ||||||
|             quote!{= value}, |             "e!{= value}, | ||||||
|             &visitor_label, |             &visitor_label, | ||||||
|             &label, |             &label, | ||||||
|             &label_name, |             &label_name, | ||||||
| @ -310,9 +312,9 @@ pub fn parse( | |||||||
|         Some(FieldType::FieldTypeU8) => { |         Some(FieldType::FieldTypeU8) => { | ||||||
|           let visitor = Ident::new("visit_u8", Span::call_site()); |           let visitor = Ident::new("visit_u8", Span::call_site()); | ||||||
|           build_call_visitor( |           build_call_visitor( | ||||||
|             quote!{u8}, |             "e!{u8}, | ||||||
|             &visitor, |             &visitor, | ||||||
|             quote!{= value}, |             "e!{= value}, | ||||||
|             &visitor_label, |             &visitor_label, | ||||||
|             &label, |             &label, | ||||||
|             &label_name, |             &label_name, | ||||||
| @ -321,9 +323,9 @@ pub fn parse( | |||||||
|         Some(FieldType::FieldTypeU16) => { |         Some(FieldType::FieldTypeU16) => { | ||||||
|           let visitor = Ident::new("visit_u16", Span::call_site()); |           let visitor = Ident::new("visit_u16", Span::call_site()); | ||||||
|           build_call_visitor( |           build_call_visitor( | ||||||
|             quote!{u16}, |             "e!{u16}, | ||||||
|             &visitor, |             &visitor, | ||||||
|             quote!{= value}, |             "e!{= value}, | ||||||
|             &visitor_label, |             &visitor_label, | ||||||
|             &label, |             &label, | ||||||
|             &label_name, |             &label_name, | ||||||
| @ -332,9 +334,9 @@ pub fn parse( | |||||||
|         Some(FieldType::FieldTypeI16) => { |         Some(FieldType::FieldTypeI16) => { | ||||||
|           let visitor = Ident::new("visit_i16", Span::call_site()); |           let visitor = Ident::new("visit_i16", Span::call_site()); | ||||||
|           build_call_visitor( |           build_call_visitor( | ||||||
|             quote!{i16}, |             "e!{i16}, | ||||||
|             &visitor, |             &visitor, | ||||||
|             quote!{= value}, |             "e!{= value}, | ||||||
|             &visitor_label, |             &visitor_label, | ||||||
|             &label, |             &label, | ||||||
|             &label_name, |             &label_name, | ||||||
| @ -343,9 +345,9 @@ pub fn parse( | |||||||
|         Some(FieldType::FieldTypeU32) => { |         Some(FieldType::FieldTypeU32) => { | ||||||
|           let visitor = Ident::new("visit_u32", Span::call_site()); |           let visitor = Ident::new("visit_u32", Span::call_site()); | ||||||
|           build_call_visitor( |           build_call_visitor( | ||||||
|             quote!{u32}, |             "e!{u32}, | ||||||
|             &visitor, |             &visitor, | ||||||
|             quote!{= value}, |             "e!{= value}, | ||||||
|             &visitor_label, |             &visitor_label, | ||||||
|             &label, |             &label, | ||||||
|             &label_name, |             &label_name, | ||||||
| @ -354,9 +356,9 @@ pub fn parse( | |||||||
|         Some(FieldType::FieldTypeI32) => { |         Some(FieldType::FieldTypeI32) => { | ||||||
|           let visitor = Ident::new("visit_i32", Span::call_site()); |           let visitor = Ident::new("visit_i32", Span::call_site()); | ||||||
|           build_call_visitor( |           build_call_visitor( | ||||||
|             quote!{i32}, |             "e!{i32}, | ||||||
|             &visitor, |             &visitor, | ||||||
|             quote!{= value}, |             "e!{= value}, | ||||||
|             &visitor_label, |             &visitor_label, | ||||||
|             &label, |             &label, | ||||||
|             &label_name, |             &label_name, | ||||||
| @ -365,9 +367,9 @@ pub fn parse( | |||||||
|         Some(FieldType::FieldTypeU64) => { |         Some(FieldType::FieldTypeU64) => { | ||||||
|           let visitor = Ident::new("visit_u64", Span::call_site()); |           let visitor = Ident::new("visit_u64", Span::call_site()); | ||||||
|           build_call_visitor( |           build_call_visitor( | ||||||
|             quote!{u64}, |             "e!{u64}, | ||||||
|             &visitor, |             &visitor, | ||||||
|             quote!{= value}, |             "e!{= value}, | ||||||
|             &visitor_label, |             &visitor_label, | ||||||
|             &label, |             &label, | ||||||
|             &label_name, |             &label_name, | ||||||
| @ -376,9 +378,9 @@ pub fn parse( | |||||||
|         Some(FieldType::FieldTypeI64) => { |         Some(FieldType::FieldTypeI64) => { | ||||||
|           let visitor = Ident::new("visit_i64", Span::call_site()); |           let visitor = Ident::new("visit_i64", Span::call_site()); | ||||||
|           build_call_visitor( |           build_call_visitor( | ||||||
|             quote!{i64}, |             "e!{i64}, | ||||||
|             &visitor, |             &visitor, | ||||||
|             quote!{= value}, |             "e!{= value}, | ||||||
|             &visitor_label, |             &visitor_label, | ||||||
|             &label, |             &label, | ||||||
|             &label_name, |             &label_name, | ||||||
| @ -404,9 +406,9 @@ pub fn parse( | |||||||
|             Some(&FieldType::FieldTypeString) => { |             Some(&FieldType::FieldTypeString) => { | ||||||
|               let visitor = Ident::new("visit_str", Span::call_site()); |               let visitor = Ident::new("visit_str", Span::call_site()); | ||||||
|               build_call_visitor( |               build_call_visitor( | ||||||
|                 quote!{String}, |                 "e!{String}, | ||||||
|                 &visitor, |                 &visitor, | ||||||
|                 quote!{.push(value)}, |                 "e!{.push(value)}, | ||||||
|                 &visitor_label, |                 &visitor_label, | ||||||
|                 &label, |                 &label, | ||||||
|                 &label_name, |                 &label_name, | ||||||
| @ -415,9 +417,9 @@ pub fn parse( | |||||||
|             Some(&FieldType::FieldTypeBool) => { |             Some(&FieldType::FieldTypeBool) => { | ||||||
|               let visitor = Ident::new("visit_bool", Span::call_site()); |               let visitor = Ident::new("visit_bool", Span::call_site()); | ||||||
|               build_call_visitor( |               build_call_visitor( | ||||||
|                 quote!{bool}, |                 "e!{bool}, | ||||||
|                 &visitor, |                 &visitor, | ||||||
|                 quote!{.push(value)}, |                 "e!{.push(value)}, | ||||||
|                 &visitor_label, |                 &visitor_label, | ||||||
|                 &label, |                 &label, | ||||||
|                 &label_name, |                 &label_name, | ||||||
| @ -426,9 +428,9 @@ pub fn parse( | |||||||
|             Some(&FieldType::FieldTypeI8) => { |             Some(&FieldType::FieldTypeI8) => { | ||||||
|               let visitor = Ident::new("visit_i8", Span::call_site()); |               let visitor = Ident::new("visit_i8", Span::call_site()); | ||||||
|               build_call_visitor( |               build_call_visitor( | ||||||
|                 quote!{i8}, |                 "e!{i8}, | ||||||
|                 &visitor, |                 &visitor, | ||||||
|                 quote!{.push(value)}, |                 "e!{.push(value)}, | ||||||
|                 &visitor_label, |                 &visitor_label, | ||||||
|                 &label, |                 &label, | ||||||
|                 &label_name, |                 &label_name, | ||||||
| @ -437,9 +439,9 @@ pub fn parse( | |||||||
|             Some(&FieldType::FieldTypeU8) => { |             Some(&FieldType::FieldTypeU8) => { | ||||||
|               let visitor = Ident::new("visit_u8", Span::call_site()); |               let visitor = Ident::new("visit_u8", Span::call_site()); | ||||||
|               build_call_visitor( |               build_call_visitor( | ||||||
|                 quote!{u8}, |                 "e!{u8}, | ||||||
|                 &visitor, |                 &visitor, | ||||||
|                 quote!{.push(value)}, |                 "e!{.push(value)}, | ||||||
|                 &visitor_label, |                 &visitor_label, | ||||||
|                 &label, |                 &label, | ||||||
|                 &label_name, |                 &label_name, | ||||||
| @ -448,9 +450,9 @@ pub fn parse( | |||||||
|             Some(&FieldType::FieldTypeI16) => { |             Some(&FieldType::FieldTypeI16) => { | ||||||
|               let visitor = Ident::new("visit_i16", Span::call_site()); |               let visitor = Ident::new("visit_i16", Span::call_site()); | ||||||
|               build_call_visitor( |               build_call_visitor( | ||||||
|                 quote!{i16}, |                 "e!{i16}, | ||||||
|                 &visitor, |                 &visitor, | ||||||
|                 quote!{.push(value)}, |                 "e!{.push(value)}, | ||||||
|                 &visitor_label, |                 &visitor_label, | ||||||
|                 &label, |                 &label, | ||||||
|                 &label_name, |                 &label_name, | ||||||
| @ -459,9 +461,9 @@ pub fn parse( | |||||||
|             Some(&FieldType::FieldTypeU16) => { |             Some(&FieldType::FieldTypeU16) => { | ||||||
|               let visitor = Ident::new("visit_u16", Span::call_site()); |               let visitor = Ident::new("visit_u16", Span::call_site()); | ||||||
|               build_call_visitor( |               build_call_visitor( | ||||||
|                 quote!{u16}, |                 "e!{u16}, | ||||||
|                 &visitor, |                 &visitor, | ||||||
|                 quote!{.push(value)}, |                 "e!{.push(value)}, | ||||||
|                 &visitor_label, |                 &visitor_label, | ||||||
|                 &label, |                 &label, | ||||||
|                 &label_name, |                 &label_name, | ||||||
| @ -470,9 +472,9 @@ pub fn parse( | |||||||
|             Some(&FieldType::FieldTypeI32) => { |             Some(&FieldType::FieldTypeI32) => { | ||||||
|               let visitor = Ident::new("visit_i32", Span::call_site()); |               let visitor = Ident::new("visit_i32", Span::call_site()); | ||||||
|               build_call_visitor( |               build_call_visitor( | ||||||
|                 quote!{i32}, |                 "e!{i32}, | ||||||
|                 &visitor, |                 &visitor, | ||||||
|                 quote!{.push(value)}, |                 "e!{.push(value)}, | ||||||
|                 &visitor_label, |                 &visitor_label, | ||||||
|                 &label, |                 &label, | ||||||
|                 &label_name, |                 &label_name, | ||||||
| @ -481,9 +483,9 @@ pub fn parse( | |||||||
|             Some(&FieldType::FieldTypeU32) => { |             Some(&FieldType::FieldTypeU32) => { | ||||||
|               let visitor = Ident::new("visit_u32", Span::call_site()); |               let visitor = Ident::new("visit_u32", Span::call_site()); | ||||||
|               build_call_visitor( |               build_call_visitor( | ||||||
|                 quote!{u32}, |                 "e!{u32}, | ||||||
|                 &visitor, |                 &visitor, | ||||||
|                 quote!{.push(value)}, |                 "e!{.push(value)}, | ||||||
|                 &visitor_label, |                 &visitor_label, | ||||||
|                 &label, |                 &label, | ||||||
|                 &label_name, |                 &label_name, | ||||||
| @ -492,9 +494,9 @@ pub fn parse( | |||||||
|             Some(&FieldType::FieldTypeI64) => { |             Some(&FieldType::FieldTypeI64) => { | ||||||
|               let visitor = Ident::new("visit_i64", Span::call_site()); |               let visitor = Ident::new("visit_i64", Span::call_site()); | ||||||
|               build_call_visitor( |               build_call_visitor( | ||||||
|                 quote!{i64}, |                 "e!{i64}, | ||||||
|                 &visitor, |                 &visitor, | ||||||
|                 quote!{.push(value)}, |                 "e!{.push(value)}, | ||||||
|                 &visitor_label, |                 &visitor_label, | ||||||
|                 &label, |                 &label, | ||||||
|                 &label_name, |                 &label_name, | ||||||
| @ -503,9 +505,9 @@ pub fn parse( | |||||||
|             Some(&FieldType::FieldTypeU64) => { |             Some(&FieldType::FieldTypeU64) => { | ||||||
|               let visitor = Ident::new("visit_u64", Span::call_site()); |               let visitor = Ident::new("visit_u64", Span::call_site()); | ||||||
|               build_call_visitor( |               build_call_visitor( | ||||||
|                 quote!{u64}, |                 "e!{u64}, | ||||||
|                 &visitor, |                 &visitor, | ||||||
|                 quote!{.push(value)}, |                 "e!{.push(value)}, | ||||||
|                 &visitor_label, |                 &visitor_label, | ||||||
|                 &label, |                 &label, | ||||||
|                 &label_name, |                 &label_name, | ||||||
| @ -602,52 +604,52 @@ pub fn parse( | |||||||
| 
 | 
 | ||||||
|       match get_field_type(field) { |       match get_field_type(field) { | ||||||
|         Some(FieldType::FieldTypeString) => { |         Some(FieldType::FieldTypeString) => { | ||||||
|           build_set_text_to_value(&field_attrs, &label, quote!{text_content.to_owned()}) |           build_set_text_to_value(&field_attrs, &label, "e!{text_content.to_owned()}) | ||||||
|         } |         } | ||||||
|         Some(FieldType::FieldTypeBool) => build_set_text_to_value( |         Some(FieldType::FieldTypeBool) => build_set_text_to_value( | ||||||
|           &field_attrs, |           &field_attrs, | ||||||
|           &label, |           &label, | ||||||
|           quote!{bool::from_str(text_content).unwrap()}, |           "e!{bool::from_str(text_content).unwrap()}, | ||||||
|         ), |         ), | ||||||
|         Some(FieldType::FieldTypeI8) => build_set_text_to_value( |         Some(FieldType::FieldTypeI8) => build_set_text_to_value( | ||||||
|           &field_attrs, |           &field_attrs, | ||||||
|           &label, |           &label, | ||||||
|           quote!{i8::from_str(text_content).unwrap()}, |           "e!{i8::from_str(text_content).unwrap()}, | ||||||
|         ), |         ), | ||||||
|         Some(FieldType::FieldTypeU8) => build_set_text_to_value( |         Some(FieldType::FieldTypeU8) => build_set_text_to_value( | ||||||
|           &field_attrs, |           &field_attrs, | ||||||
|           &label, |           &label, | ||||||
|           quote!{u8::from_str(text_content).unwrap()}, |           "e!{u8::from_str(text_content).unwrap()}, | ||||||
|         ), |         ), | ||||||
|         Some(FieldType::FieldTypeI16) => build_set_text_to_value( |         Some(FieldType::FieldTypeI16) => build_set_text_to_value( | ||||||
|           &field_attrs, |           &field_attrs, | ||||||
|           &label, |           &label, | ||||||
|           quote!{i16::from_str(text_content).unwrap()}, |           "e!{i16::from_str(text_content).unwrap()}, | ||||||
|         ), |         ), | ||||||
|         Some(FieldType::FieldTypeU16) => build_set_text_to_value( |         Some(FieldType::FieldTypeU16) => build_set_text_to_value( | ||||||
|           &field_attrs, |           &field_attrs, | ||||||
|           &label, |           &label, | ||||||
|           quote!{u16::from_str(text_content).unwrap()}, |           "e!{u16::from_str(text_content).unwrap()}, | ||||||
|         ), |         ), | ||||||
|         Some(FieldType::FieldTypeI32) => build_set_text_to_value( |         Some(FieldType::FieldTypeI32) => build_set_text_to_value( | ||||||
|           &field_attrs, |           &field_attrs, | ||||||
|           &label, |           &label, | ||||||
|           quote!{i32::from_str(text_content).unwrap()}, |           "e!{i32::from_str(text_content).unwrap()}, | ||||||
|         ), |         ), | ||||||
|         Some(FieldType::FieldTypeU32) => build_set_text_to_value( |         Some(FieldType::FieldTypeU32) => build_set_text_to_value( | ||||||
|           &field_attrs, |           &field_attrs, | ||||||
|           &label, |           &label, | ||||||
|           quote!{u32::from_str(text_content).unwrap()}, |           "e!{u32::from_str(text_content).unwrap()}, | ||||||
|         ), |         ), | ||||||
|         Some(FieldType::FieldTypeI64) => build_set_text_to_value( |         Some(FieldType::FieldTypeI64) => build_set_text_to_value( | ||||||
|           &field_attrs, |           &field_attrs, | ||||||
|           &label, |           &label, | ||||||
|           quote!{i64::from_str(text_content).unwrap()}, |           "e!{i64::from_str(text_content).unwrap()}, | ||||||
|         ), |         ), | ||||||
|         Some(FieldType::FieldTypeU64) => build_set_text_to_value( |         Some(FieldType::FieldTypeU64) => build_set_text_to_value( | ||||||
|           &field_attrs, |           &field_attrs, | ||||||
|           &label, |           &label, | ||||||
|           quote!{u64::from_str(text_content).unwrap()}, |           "e!{u64::from_str(text_content).unwrap()}, | ||||||
|         ), |         ), | ||||||
| 
 | 
 | ||||||
|         Some(FieldType::FieldTypeStruct { .. }) | Some(FieldType::FieldTypeVec { .. }) | None => { |         Some(FieldType::FieldTypeStruct { .. }) | Some(FieldType::FieldTypeVec { .. }) | None => { | ||||||
| @ -743,8 +745,8 @@ pub fn parse( | |||||||
| 
 | 
 | ||||||
| fn build_default_value( | fn build_default_value( | ||||||
|   label: &Option<Ident>, |   label: &Option<Ident>, | ||||||
|   field_type: Tokens, |   field_type: &Tokens, | ||||||
|   default: Tokens, |   default: &Tokens, | ||||||
| ) -> Option<Tokens> { | ) -> Option<Tokens> { | ||||||
|   Some(quote!{ |   Some(quote!{ | ||||||
|     #[allow(unused_mut)] |     #[allow(unused_mut)] | ||||||
| @ -753,7 +755,7 @@ fn build_default_value( | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| fn build_declare_visitor( | fn build_declare_visitor( | ||||||
|   field_type: Tokens, |   field_type: &Tokens, | ||||||
|   visitor: &Ident, |   visitor: &Ident, | ||||||
|   visitor_label: &Ident, |   visitor_label: &Ident, | ||||||
| ) -> Option<Tokens> { | ) -> Option<Tokens> { | ||||||
| @ -771,12 +773,12 @@ fn build_declare_visitor( | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| fn build_call_visitor( | fn build_call_visitor( | ||||||
|   field_type: Tokens, |   field_type: &Tokens, | ||||||
|   visitor: &Ident, |   visitor: &Ident, | ||||||
|   action: Tokens, |   action: &Tokens, | ||||||
|   visitor_label: &Ident, |   visitor_label: &Ident, | ||||||
|   label: &Option<Ident>, |   label: &Option<Ident>, | ||||||
|   label_name: &String, |   label_name: &str, | ||||||
| ) -> Option<Tokens> { | ) -> Option<Tokens> { | ||||||
|   Some(quote!{ |   Some(quote!{ | ||||||
|     #label_name => { |     #label_name => { | ||||||
| @ -799,7 +801,6 @@ fn build_call_visitor( | |||||||
|       }); |       }); | ||||||
| 
 | 
 | ||||||
|       if let Ok(value) = result { |       if let Ok(value) = result { | ||||||
|         // #label = value
 |  | ||||||
|         #label#action |         #label#action | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
| @ -809,7 +810,7 @@ fn build_call_visitor( | |||||||
| fn build_set_text_to_value( | fn build_set_text_to_value( | ||||||
|   field_attrs: &YaSerdeAttribute, |   field_attrs: &YaSerdeAttribute, | ||||||
|   label: &Option<Ident>, |   label: &Option<Ident>, | ||||||
|   action: Tokens, |   action: &Tokens, | ||||||
| ) -> Option<Tokens> { | ) -> Option<Tokens> { | ||||||
|   if field_attrs.text { |   if field_attrs.text { | ||||||
|     Some(quote!{ |     Some(quote!{ | ||||||
|  | |||||||
| @ -13,16 +13,16 @@ pub fn expand_derive_deserialize(ast: &syn::DeriveInput) -> Result<quote::Tokens | |||||||
|   let data = &ast.data; |   let data = &ast.data; | ||||||
| 
 | 
 | ||||||
|   let root_attrs = attribute::YaSerdeAttribute::parse(&attrs); |   let root_attrs = attribute::YaSerdeAttribute::parse(&attrs); | ||||||
|   let root = root_attrs.clone().root.unwrap_or(name.to_string()); |   let root = root_attrs.clone().root.unwrap_or_else(|| name.to_string()); | ||||||
| 
 | 
 | ||||||
|   let impl_block = match data { |   let impl_block = match *data { | ||||||
|     &syn::Data::Struct(ref data_struct) => { |     syn::Data::Struct(ref data_struct) => { | ||||||
|       expand_struct::parse(data_struct, &name, &root, &root_attrs.namespaces) |       expand_struct::parse(data_struct, &name, &root, &root_attrs.namespaces) | ||||||
|     } |     } | ||||||
|     &syn::Data::Enum(ref data_enum) => { |     syn::Data::Enum(ref data_enum) => { | ||||||
|       expand_enum::parse(data_enum, &name, &root, &root_attrs.namespaces) |       expand_enum::parse(data_enum, &name, &root, &root_attrs.namespaces) | ||||||
|     } |     } | ||||||
|     &syn::Data::Union(ref _data_union) => unimplemented!(), |     syn::Data::Union(ref _data_union) => unimplemented!(), | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   let dummy_const = Ident::new( |   let dummy_const = Ident::new( | ||||||
|  | |||||||
| @ -61,8 +61,8 @@ pub fn get_field_type(field: &syn::Field) -> Option<FieldType> { | |||||||
| fn get_vec_type(t: &syn::PathSegment) -> Option<syn::Ident> { | fn get_vec_type(t: &syn::PathSegment) -> Option<syn::Ident> { | ||||||
|   if let syn::PathArguments::AngleBracketed(ref args) = t.arguments { |   if let syn::PathArguments::AngleBracketed(ref args) = t.arguments { | ||||||
|     if let Some(Pair::End(tt)) = args.args.first() { |     if let Some(Pair::End(tt)) = args.args.first() { | ||||||
|       if let &syn::GenericArgument::Type(ref argument) = tt { |       if let syn::GenericArgument::Type(ref argument) = *tt { | ||||||
|         if let &Path(ref path2) = argument { |         if let Path(ref path2) = argument { | ||||||
|           if let Some(Pair::End(ttt)) = path2.path.segments.first() { |           if let Some(Pair::End(ttt)) = path2.path.segments.first() { | ||||||
|             return Some(ttt.ident); |             return Some(ttt.ident); | ||||||
|           } |           } | ||||||
|  | |||||||
| @ -10,7 +10,7 @@ use proc_macro2::Span; | |||||||
| pub fn serialize( | pub fn serialize( | ||||||
|   data_enum: &DataEnum, |   data_enum: &DataEnum, | ||||||
|   name: &Ident, |   name: &Ident, | ||||||
|   root: &String, |   root: &str, | ||||||
|   namespaces: &BTreeMap<String, String>, |   namespaces: &BTreeMap<String, String>, | ||||||
| ) -> Tokens { | ) -> Tokens { | ||||||
|   let write_enum_content: Tokens = data_enum |   let write_enum_content: Tokens = data_enum | ||||||
| @ -42,12 +42,12 @@ pub fn serialize( | |||||||
|             .iter() |             .iter() | ||||||
|             .map(|ref field| { |             .map(|ref field| { | ||||||
|               let field_attrs = YaSerdeAttribute::parse(&field.attrs); |               let field_attrs = YaSerdeAttribute::parse(&field.attrs); | ||||||
|               if field_attrs.attribute == true { |               if field_attrs.attribute { | ||||||
|                 return None; |                 return None; | ||||||
|               } |               } | ||||||
| 
 | 
 | ||||||
|               let field_label = field.ident; |               let field_label = field.ident; | ||||||
|               if field_attrs.text == true { |               if field_attrs.text { | ||||||
|                 return Some(quote!( |                 return Some(quote!( | ||||||
|                 let data_event = XmlEvent::characters(&self.#field_label); |                 let data_event = XmlEvent::characters(&self.#field_label); | ||||||
|                 let _ret = writer.write(data_event); |                 let _ret = writer.write(data_event); | ||||||
|  | |||||||
| @ -10,7 +10,7 @@ use std::string::ToString; | |||||||
| pub fn serialize( | pub fn serialize( | ||||||
|   data_struct: &DataStruct, |   data_struct: &DataStruct, | ||||||
|   name: &Ident, |   name: &Ident, | ||||||
|   root: &String, |   root: &str, | ||||||
|   namespaces: &BTreeMap<String, String>, |   namespaces: &BTreeMap<String, String>, | ||||||
| ) -> Tokens { | ) -> Tokens { | ||||||
|   let build_attributes: Tokens = data_struct |   let build_attributes: Tokens = data_struct | ||||||
| @ -18,7 +18,7 @@ pub fn serialize( | |||||||
|     .iter() |     .iter() | ||||||
|     .map(|ref field| { |     .map(|ref field| { | ||||||
|       let field_attrs = YaSerdeAttribute::parse(&field.attrs); |       let field_attrs = YaSerdeAttribute::parse(&field.attrs); | ||||||
|       if field_attrs.attribute == false { |       if !field_attrs.attribute { | ||||||
|         return None; |         return None; | ||||||
|       } |       } | ||||||
| 
 | 
 | ||||||
| @ -90,12 +90,12 @@ pub fn serialize( | |||||||
|     .iter() |     .iter() | ||||||
|     .map(|ref field| { |     .map(|ref field| { | ||||||
|       let field_attrs = YaSerdeAttribute::parse(&field.attrs); |       let field_attrs = YaSerdeAttribute::parse(&field.attrs); | ||||||
|       if field_attrs.attribute == true { |       if field_attrs.attribute { | ||||||
|         return None; |         return None; | ||||||
|       } |       } | ||||||
| 
 | 
 | ||||||
|       let label = field.ident; |       let label = field.ident; | ||||||
|       if field_attrs.text == true { |       if field_attrs.text { | ||||||
|         return Some(quote!( |         return Some(quote!( | ||||||
|           let data_event = XmlEvent::characters(&self.#label); |           let data_event = XmlEvent::characters(&self.#label); | ||||||
|           let _ret = writer.write(data_event); |           let _ret = writer.write(data_event); | ||||||
|  | |||||||
| @ -13,7 +13,7 @@ pub fn expand_derive_serialize(ast: &syn::DeriveInput) -> Result<quote::Tokens, | |||||||
|   let data = &ast.data; |   let data = &ast.data; | ||||||
| 
 | 
 | ||||||
|   let root_attrs = attribute::YaSerdeAttribute::parse(&attrs); |   let root_attrs = attribute::YaSerdeAttribute::parse(&attrs); | ||||||
|   let root = root_attrs.clone().root.unwrap_or(name.to_string()); |   let root = root_attrs.clone().root.unwrap_or_else(|| name.to_string()); | ||||||
| 
 | 
 | ||||||
|   let root = if let Some(prefix) = root_attrs.prefix { |   let root = if let Some(prefix) = root_attrs.prefix { | ||||||
|     prefix + ":" + &root |     prefix + ":" + &root | ||||||
| @ -21,14 +21,14 @@ pub fn expand_derive_serialize(ast: &syn::DeriveInput) -> Result<quote::Tokens, | |||||||
|     root |     root | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   let impl_block = match data { |   let impl_block = match *data { | ||||||
|     &syn::Data::Struct(ref data_struct) => { |     syn::Data::Struct(ref data_struct) => { | ||||||
|       expand_struct::serialize(data_struct, &name, &root, &root_attrs.namespaces) |       expand_struct::serialize(data_struct, &name, &root, &root_attrs.namespaces) | ||||||
|     } |     } | ||||||
|     &syn::Data::Enum(ref data_enum) => { |     syn::Data::Enum(ref data_enum) => { | ||||||
|       expand_enum::serialize(data_enum, &name, &root, &root_attrs.namespaces) |       expand_enum::serialize(data_enum, &name, &root, &root_attrs.namespaces) | ||||||
|     } |     } | ||||||
|     &syn::Data::Union(ref _data_union) => unimplemented!(), |     syn::Data::Union(ref _data_union) => unimplemented!(), | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   let dummy_const = Ident::new( |   let dummy_const = Ident::new( | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user