mirror of
https://github.com/fluencelabs/marine-rs-sdk-test
synced 2024-12-04 23:30:18 +00:00
refactoring
This commit is contained in:
parent
7314000623
commit
7e19dfb4fb
@ -85,8 +85,8 @@ fn generate_serializer_fn(record: &fce_ast_types::AstRecordItem) -> proc_macro2:
|
||||
|
||||
fn generate_deserializer_fn(record: &fce_ast_types::AstRecordItem) -> proc_macro2::TokenStream {
|
||||
let RecordDerDescriptor {
|
||||
fields_der: deserializer,
|
||||
record_ctor: type_constructor,
|
||||
fields_der,
|
||||
record_ctor,
|
||||
} = record.generate_der();
|
||||
|
||||
let record_size =
|
||||
@ -96,9 +96,9 @@ fn generate_deserializer_fn(record: &fce_ast_types::AstRecordItem) -> proc_macro
|
||||
pub unsafe fn __fce_generated_deserialize(record_ptr: *const u8) -> Self {
|
||||
let raw_record: Vec<u64> = Vec::from_raw_parts(record_ptr as _, #record_size, #record_size);
|
||||
|
||||
#deserializer
|
||||
#fields_der
|
||||
|
||||
#type_constructor
|
||||
#record_ctor
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -172,6 +172,16 @@ fn build_record_ctor<'a, 'v>(
|
||||
};
|
||||
|
||||
if is_fields_named {
|
||||
build_named_fields_ctor(ast_fields, field_values)
|
||||
} else {
|
||||
build_unnamed_fields_ctor(field_values)
|
||||
}
|
||||
}
|
||||
|
||||
fn build_named_fields_ctor<'a, 'v>(
|
||||
ast_fields: impl ExactSizeIterator<Item = &'a fce_ast_types::AstRecordField>,
|
||||
field_values: impl ExactSizeIterator<Item = &'v syn::Ident>,
|
||||
) -> proc_macro2::TokenStream {
|
||||
let field_names = ast_fields
|
||||
.map(|ast_field| {
|
||||
new_ident!(ast_field
|
||||
@ -186,11 +196,14 @@ fn build_record_ctor<'a, 'v>(
|
||||
#(#field_names: #field_values),*
|
||||
}
|
||||
}
|
||||
} else {
|
||||
}
|
||||
|
||||
fn build_unnamed_fields_ctor<'v>(
|
||||
field_values: impl ExactSizeIterator<Item = &'v syn::Ident>,
|
||||
) -> proc_macro2::TokenStream {
|
||||
quote! {
|
||||
Self (
|
||||
Self {
|
||||
#(#field_values),*
|
||||
)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user