skip serialization if value equals to default
This commit is contained in:
24
yaserde_derive/src/de/build_default_value.rs
Normal file
24
yaserde_derive/src/de/build_default_value.rs
Normal file
@@ -0,0 +1,24 @@
|
||||
|
||||
use proc_macro2::{Span, TokenStream};
|
||||
use syn::Ident;
|
||||
|
||||
pub fn build_default_value(
|
||||
label: &Option<Ident>,
|
||||
field_type: &TokenStream,
|
||||
value: &TokenStream,
|
||||
default: &Option<String>,
|
||||
) -> Option<TokenStream> {
|
||||
if let Some(d) = default {
|
||||
let default_function = Ident::new(&d, Span::call_site());
|
||||
|
||||
Some(quote! {
|
||||
#[allow(unused_mut)]
|
||||
let mut #label : #field_type = #default_function();
|
||||
})
|
||||
} else {
|
||||
Some(quote! {
|
||||
#[allow(unused_mut)]
|
||||
let mut #label : #field_type = #value;
|
||||
})
|
||||
}
|
||||
}
|
||||
@@ -6,6 +6,7 @@ use std::collections::BTreeMap;
|
||||
use syn::DataEnum;
|
||||
use syn::Fields;
|
||||
use syn::Ident;
|
||||
use de::build_default_value::build_default_value;
|
||||
|
||||
pub fn parse(
|
||||
data_enum: &DataEnum,
|
||||
@@ -24,95 +25,111 @@ pub fn parse(
|
||||
.iter()
|
||||
.map(|field| {
|
||||
let field_label = &field.ident;
|
||||
let field_attrs = YaSerdeAttribute::parse(&field.attrs);
|
||||
|
||||
match get_field_type(field) {
|
||||
Some(FieldType::FieldTypeString) => {
|
||||
build_default_value(field_label, "e!{String}, "e!{"".to_string()})
|
||||
build_default_value(field_label, "e! {String}, "e! {"".to_string()}, &field_attrs.default)
|
||||
}
|
||||
Some(FieldType::FieldTypeBool) => {
|
||||
build_default_value(field_label, "e!{bool}, "e!{false})
|
||||
build_default_value(field_label, "e! {bool}, "e! {false}, &field_attrs.default)
|
||||
}
|
||||
Some(FieldType::FieldTypeI8) => {
|
||||
build_default_value(field_label, "e!{i8}, "e!{0})
|
||||
build_default_value(field_label, "e! {i8}, "e! {0}, &field_attrs.default)
|
||||
}
|
||||
Some(FieldType::FieldTypeU8) => {
|
||||
build_default_value(field_label, "e!{u8}, "e!{0})
|
||||
build_default_value(field_label, "e! {u8}, "e! {0}, &field_attrs.default)
|
||||
}
|
||||
Some(FieldType::FieldTypeI16) => {
|
||||
build_default_value(field_label, "e!{i16}, "e!{0})
|
||||
build_default_value(field_label, "e! {i16}, "e! {0}, &field_attrs.default)
|
||||
}
|
||||
Some(FieldType::FieldTypeU16) => {
|
||||
build_default_value(field_label, "e!{u16}, "e!{0})
|
||||
build_default_value(field_label, "e! {u16}, "e! {0}, &field_attrs.default)
|
||||
}
|
||||
Some(FieldType::FieldTypeI32) => {
|
||||
build_default_value(field_label, "e!{i32}, "e!{0})
|
||||
build_default_value(field_label, "e! {i32}, "e! {0}, &field_attrs.default)
|
||||
}
|
||||
Some(FieldType::FieldTypeU32) => {
|
||||
build_default_value(field_label, "e!{u32}, "e!{0})
|
||||
build_default_value(field_label, "e! {u32}, "e! {0}, &field_attrs.default)
|
||||
}
|
||||
Some(FieldType::FieldTypeI64) => {
|
||||
build_default_value(field_label, "e!{i64}, "e!{0})
|
||||
build_default_value(field_label, "e! {i64}, "e! {0}, &field_attrs.default)
|
||||
}
|
||||
Some(FieldType::FieldTypeU64) => {
|
||||
build_default_value(field_label, "e!{u64}, "e!{0})
|
||||
build_default_value(field_label, "e! {u64}, "e! {0}, &field_attrs.default)
|
||||
}
|
||||
Some(FieldType::FieldTypeF32) => {
|
||||
build_default_value(field_label, "e!{f32}, "e!{0})
|
||||
build_default_value(field_label, "e! {f32}, "e! {0}, &field_attrs.default)
|
||||
}
|
||||
Some(FieldType::FieldTypeF64) => {
|
||||
build_default_value(field_label, "e!{f64}, "e!{0})
|
||||
build_default_value(field_label, "e! {f64}, "e! {0}, &field_attrs.default)
|
||||
}
|
||||
Some(FieldType::FieldTypeStruct { struct_name }) => build_default_value(
|
||||
field_label,
|
||||
"e! {#struct_name},
|
||||
"e! {#struct_name::default()},
|
||||
&field_attrs.default,
|
||||
),
|
||||
Some(FieldType::FieldTypeOption { .. }) => {
|
||||
if let Some(d) = &field_attrs.default {
|
||||
let default_function = Ident::new(&d, Span::call_site());
|
||||
|
||||
Some(quote! {
|
||||
#[allow(unused_mut, non_snake_case, non_camel_case_types)]
|
||||
let mut #field_label = #default_function();
|
||||
})
|
||||
} else {
|
||||
Some(quote! {
|
||||
#[allow(unused_mut, non_snake_case, non_camel_case_types)]
|
||||
let mut #field_label = None;
|
||||
})
|
||||
}
|
||||
}
|
||||
Some(FieldType::FieldTypeStruct { struct_name }) => Some(quote!{
|
||||
#[allow(unused_mut)]
|
||||
let mut #field_label : #struct_name = #struct_name::default();
|
||||
}),
|
||||
Some(FieldType::FieldTypeOption { .. }) => Some(quote!{
|
||||
#[allow(unused_mut)]
|
||||
let mut #field_label = None;
|
||||
}),
|
||||
Some(FieldType::FieldTypeVec { data_type }) => {
|
||||
let dt = Box::into_raw(data_type);
|
||||
match unsafe { dt.as_ref() } {
|
||||
Some(&FieldType::FieldTypeString) => {
|
||||
build_default_value(field_label, "e!{Vec<String>}, "e!{vec![]})
|
||||
build_default_value(field_label, "e! {Vec<String>}, "e! {vec![]}, &field_attrs.default)
|
||||
}
|
||||
Some(&FieldType::FieldTypeBool) => {
|
||||
build_default_value(field_label, "e!{Vec<bool>}, "e!{vec![]})
|
||||
build_default_value(field_label, "e! {Vec<bool>}, "e! {vec![]}, &field_attrs.default)
|
||||
}
|
||||
Some(&FieldType::FieldTypeI8) => {
|
||||
build_default_value(field_label, "e!{Vec<i8>}, "e!{vec![]})
|
||||
build_default_value(field_label, "e! {Vec<i8>}, "e! {vec![]}, &field_attrs.default)
|
||||
}
|
||||
Some(&FieldType::FieldTypeU8) => {
|
||||
build_default_value(field_label, "e!{Vec<u8>}, "e!{vec![]})
|
||||
build_default_value(field_label, "e! {Vec<u8>}, "e! {vec![]}, &field_attrs.default)
|
||||
}
|
||||
Some(&FieldType::FieldTypeI16) => {
|
||||
build_default_value(field_label, "e!{Vec<i16>}, "e!{vec![]})
|
||||
build_default_value(field_label, "e! {Vec<i16>}, "e! {vec![]}, &field_attrs.default)
|
||||
}
|
||||
Some(&FieldType::FieldTypeU16) => {
|
||||
build_default_value(field_label, "e!{Vec<u16>}, "e!{vec![]})
|
||||
build_default_value(field_label, "e! {Vec<u16>}, "e! {vec![]}, &field_attrs.default)
|
||||
}
|
||||
Some(&FieldType::FieldTypeI32) => {
|
||||
build_default_value(field_label, "e!{Vec<i32>}, "e!{vec![]})
|
||||
build_default_value(field_label, "e! {Vec<i32>}, "e! {vec![]}, &field_attrs.default)
|
||||
}
|
||||
Some(&FieldType::FieldTypeU32) => {
|
||||
build_default_value(field_label, "e!{Vec<u32>}, "e!{vec![]})
|
||||
build_default_value(field_label, "e! {Vec<u32>}, "e! {vec![]}, &field_attrs.default)
|
||||
}
|
||||
Some(&FieldType::FieldTypeI64) => {
|
||||
build_default_value(field_label, "e!{Vec<i64>}, "e!{vec![]})
|
||||
build_default_value(field_label, "e! {Vec<i64>}, "e! {vec![]}, &field_attrs.default)
|
||||
}
|
||||
Some(&FieldType::FieldTypeU64) => {
|
||||
build_default_value(field_label, "e!{Vec<u64>}, "e!{vec![]})
|
||||
build_default_value(field_label, "e! {Vec<u64>}, "e! {vec![]}, &field_attrs.default)
|
||||
}
|
||||
Some(&FieldType::FieldTypeF32) => {
|
||||
build_default_value(field_label, "e!{Vec<f32>}, "e!{vec![]})
|
||||
build_default_value(field_label, "e! {Vec<f32>}, "e! {vec![]}, &field_attrs.default)
|
||||
}
|
||||
Some(&FieldType::FieldTypeF64) => {
|
||||
build_default_value(field_label, "e!{Vec<f64>}, "e!{vec![]})
|
||||
build_default_value(field_label, "e! {Vec<f64>}, "e! {vec![]}, &field_attrs.default)
|
||||
}
|
||||
Some(&FieldType::FieldTypeStruct { ref struct_name }) => Some(quote!{
|
||||
#[allow(unused_mut)]
|
||||
let mut #field_label : Vec<#struct_name> = vec![];
|
||||
}),
|
||||
Some(&FieldType::FieldTypeStruct { ref struct_name }) => build_default_value(
|
||||
field_label,
|
||||
"e! {Vec<#struct_name>},
|
||||
"e! {vec![]},
|
||||
&field_attrs.default,
|
||||
),
|
||||
Some(&FieldType::FieldTypeOption { .. })
|
||||
| Some(&FieldType::FieldTypeVec { .. }) => {
|
||||
unimplemented!();
|
||||
@@ -158,7 +175,7 @@ pub fn parse(
|
||||
let label_name = renamed_label.to_string();
|
||||
|
||||
match variant.fields {
|
||||
Fields::Unit => Some(quote!{
|
||||
Fields::Unit => Some(quote! {
|
||||
#label_name => {
|
||||
simple_enum_value = Some(#name::#label);
|
||||
}
|
||||
@@ -173,7 +190,7 @@ pub fn parse(
|
||||
tokens
|
||||
});
|
||||
|
||||
quote!{
|
||||
quote! {
|
||||
use xml::reader::XmlEvent;
|
||||
|
||||
impl YaDeserialize for #name {
|
||||
@@ -232,14 +249,3 @@ pub fn parse(
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
fn build_default_value(
|
||||
label: &Option<Ident>,
|
||||
field_type: &TokenStream,
|
||||
default: &TokenStream,
|
||||
) -> Option<TokenStream> {
|
||||
Some(quote!{
|
||||
#[allow(unused_mut)]
|
||||
let mut #label : #field_type = #default;
|
||||
})
|
||||
}
|
||||
|
||||
File diff suppressed because it is too large
Load Diff
@@ -1,3 +1,5 @@
|
||||
|
||||
pub mod build_default_value;
|
||||
pub mod expand_enum;
|
||||
pub mod expand_struct;
|
||||
|
||||
|
||||
Reference in New Issue
Block a user