use Tokens instead of Ident
This commit is contained in:
parent
dfe276d231
commit
6ce72187aa
@ -130,44 +130,34 @@ pub fn parse(
|
||||
|
||||
match get_field_type(field) {
|
||||
Some(FieldType::FieldTypeString) => {
|
||||
let visitor = Ident::new("visit_str", Span::call_site());
|
||||
build_declare_visitor("e!{String}, &visitor, &visitor_label)
|
||||
build_declare_visitor("e!{String}, "e!{visit_str}, &visitor_label)
|
||||
}
|
||||
Some(FieldType::FieldTypeBool) => {
|
||||
let visitor = Ident::new("visit_bool", Span::call_site());
|
||||
build_declare_visitor("e!{bool}, &visitor, &visitor_label)
|
||||
build_declare_visitor("e!{bool}, "e!{visit_bool}, &visitor_label)
|
||||
}
|
||||
Some(FieldType::FieldTypeI8) => {
|
||||
let visitor = Ident::new("visit_i8", Span::call_site());
|
||||
build_declare_visitor("e!{i8}, &visitor, &visitor_label)
|
||||
build_declare_visitor("e!{i8}, "e!{visit_i8}, &visitor_label)
|
||||
}
|
||||
Some(FieldType::FieldTypeU8) => {
|
||||
let visitor = Ident::new("visit_u8", Span::call_site());
|
||||
build_declare_visitor("e!{u8}, &visitor, &visitor_label)
|
||||
build_declare_visitor("e!{u8}, "e!{visit_u8}, &visitor_label)
|
||||
}
|
||||
Some(FieldType::FieldTypeI16) => {
|
||||
let visitor = Ident::new("visit_i16", Span::call_site());
|
||||
build_declare_visitor("e!{i16}, &visitor, &visitor_label)
|
||||
build_declare_visitor("e!{i16}, "e!{visit_i16}, &visitor_label)
|
||||
}
|
||||
Some(FieldType::FieldTypeU16) => {
|
||||
let visitor = Ident::new("visit_u16", Span::call_site());
|
||||
build_declare_visitor("e!{u16}, &visitor, &visitor_label)
|
||||
build_declare_visitor("e!{u16}, "e!{visit_u16}, &visitor_label)
|
||||
}
|
||||
Some(FieldType::FieldTypeI32) => {
|
||||
let visitor = Ident::new("visit_i32", Span::call_site());
|
||||
build_declare_visitor("e!{i32}, &visitor, &visitor_label)
|
||||
build_declare_visitor("e!{i32}, "e!{visit_i32}, &visitor_label)
|
||||
}
|
||||
Some(FieldType::FieldTypeU32) => {
|
||||
let visitor = Ident::new("visit_u32", Span::call_site());
|
||||
build_declare_visitor("e!{u32}, &visitor, &visitor_label)
|
||||
build_declare_visitor("e!{u32}, "e!{visit_u32}, &visitor_label)
|
||||
}
|
||||
Some(FieldType::FieldTypeI64) => {
|
||||
let visitor = Ident::new("visit_i64", Span::call_site());
|
||||
build_declare_visitor("e!{i64}, &visitor, &visitor_label)
|
||||
build_declare_visitor("e!{i64}, "e!{visit_i64}, &visitor_label)
|
||||
}
|
||||
Some(FieldType::FieldTypeU64) => {
|
||||
let visitor = Ident::new("visit_u64", Span::call_site());
|
||||
build_declare_visitor("e!{u64}, &visitor, &visitor_label)
|
||||
build_declare_visitor("e!{u64}, "e!{visit_u64}, &visitor_label)
|
||||
}
|
||||
Some(FieldType::FieldTypeStruct { struct_name }) => {
|
||||
let struct_id = struct_name.to_string();
|
||||
@ -194,44 +184,34 @@ pub fn parse(
|
||||
let dt = Box::into_raw(data_type);
|
||||
match unsafe { dt.as_ref() } {
|
||||
Some(&FieldType::FieldTypeString) => {
|
||||
let visitor = Ident::new("visit_str", Span::call_site());
|
||||
build_declare_visitor("e!{String}, &visitor, &visitor_label)
|
||||
build_declare_visitor("e!{String}, "e!{visit_str}, &visitor_label)
|
||||
}
|
||||
Some(&FieldType::FieldTypeBool) => {
|
||||
let visitor = Ident::new("visit_bool", Span::call_site());
|
||||
build_declare_visitor("e!{bool}, &visitor, &visitor_label)
|
||||
build_declare_visitor("e!{bool}, "e!{visit_bool}, &visitor_label)
|
||||
}
|
||||
Some(&FieldType::FieldTypeI8) => {
|
||||
let visitor = Ident::new("visit_i8", Span::call_site());
|
||||
build_declare_visitor("e!{i8}, &visitor, &visitor_label)
|
||||
build_declare_visitor("e!{i8}, "e!{visit_i8}, &visitor_label)
|
||||
}
|
||||
Some(&FieldType::FieldTypeU8) => {
|
||||
let visitor = Ident::new("visit_u8", Span::call_site());
|
||||
build_declare_visitor("e!{u8}, &visitor, &visitor_label)
|
||||
build_declare_visitor("e!{u8}, "e!{visit_u8}, &visitor_label)
|
||||
}
|
||||
Some(&FieldType::FieldTypeI16) => {
|
||||
let visitor = Ident::new("visit_i16", Span::call_site());
|
||||
build_declare_visitor("e!{i16}, &visitor, &visitor_label)
|
||||
build_declare_visitor("e!{i16}, "e!{visit_i16}, &visitor_label)
|
||||
}
|
||||
Some(&FieldType::FieldTypeU16) => {
|
||||
let visitor = Ident::new("visit_u16", Span::call_site());
|
||||
build_declare_visitor("e!{u16}, &visitor, &visitor_label)
|
||||
build_declare_visitor("e!{u16}, "e!{visit_u16}, &visitor_label)
|
||||
}
|
||||
Some(&FieldType::FieldTypeI32) => {
|
||||
let visitor = Ident::new("visit_i32", Span::call_site());
|
||||
build_declare_visitor("e!{i32}, &visitor, &visitor_label)
|
||||
build_declare_visitor("e!{i32}, "e!{visit_i32}, &visitor_label)
|
||||
}
|
||||
Some(&FieldType::FieldTypeU32) => {
|
||||
let visitor = Ident::new("visit_u32", Span::call_site());
|
||||
build_declare_visitor("e!{u32}, &visitor, &visitor_label)
|
||||
build_declare_visitor("e!{u32}, "e!{visit_u32}, &visitor_label)
|
||||
}
|
||||
Some(&FieldType::FieldTypeI64) => {
|
||||
let visitor = Ident::new("visit_i64", Span::call_site());
|
||||
build_declare_visitor("e!{i64}, &visitor, &visitor_label)
|
||||
build_declare_visitor("e!{i64}, "e!{visit_i64}, &visitor_label)
|
||||
}
|
||||
Some(&FieldType::FieldTypeU64) => {
|
||||
let visitor = Ident::new("visit_u64", Span::call_site());
|
||||
build_declare_visitor("e!{u64}, &visitor, &visitor_label)
|
||||
build_declare_visitor("e!{u64}, "e!{visit_u64}, &visitor_label)
|
||||
}
|
||||
Some(&FieldType::FieldTypeStruct { struct_name }) => {
|
||||
let struct_ident = Ident::new(&format!("{}", struct_name), Span::def_site());
|
||||
@ -786,7 +766,7 @@ fn build_default_value(
|
||||
|
||||
fn build_declare_visitor(
|
||||
field_type: &Tokens,
|
||||
visitor: &Ident,
|
||||
visitor: &Tokens,
|
||||
visitor_label: &Ident,
|
||||
) -> Option<Tokens> {
|
||||
Some(quote!{
|
||||
|
||||
Loading…
Reference in New Issue
Block a user