diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 17:39:49 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 17:39:49 +0000 |
commit | a0aa2307322cd47bbf416810ac0292925e03be87 (patch) | |
tree | 37076262a026c4b48c8a0e84f44ff9187556ca35 /rust/vendor/asn1-rs-derive/src/sequence.rs | |
parent | Initial commit. (diff) | |
download | suricata-a0aa2307322cd47bbf416810ac0292925e03be87.tar.xz suricata-a0aa2307322cd47bbf416810ac0292925e03be87.zip |
Adding upstream version 1:7.0.3.upstream/1%7.0.3
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'rust/vendor/asn1-rs-derive/src/sequence.rs')
-rw-r--r-- | rust/vendor/asn1-rs-derive/src/sequence.rs | 61 |
1 files changed, 61 insertions, 0 deletions
diff --git a/rust/vendor/asn1-rs-derive/src/sequence.rs b/rust/vendor/asn1-rs-derive/src/sequence.rs new file mode 100644 index 0000000..8a0d249 --- /dev/null +++ b/rust/vendor/asn1-rs-derive/src/sequence.rs @@ -0,0 +1,61 @@ +use crate::container::*; +use proc_macro2::Span; +use quote::quote; +use syn::{Data, Ident}; + +pub fn derive_ber_sequence(s: synstructure::Structure) -> proc_macro2::TokenStream { + let ast = s.ast(); + + let container = match &ast.data { + Data::Struct(ds) => Container::from_datastruct(ds, ast, ContainerType::Sequence), + _ => panic!("Unsupported type, cannot derive"), + }; + + let debug_derive = ast.attrs.iter().any(|attr| { + attr.path + .is_ident(&Ident::new("debug_derive", Span::call_site())) + }); + + let impl_tryfrom = container.gen_tryfrom(); + let impl_tagged = container.gen_tagged(); + let ts = s.gen_impl(quote! { + extern crate asn1_rs; + + #impl_tryfrom + #impl_tagged + }); + if debug_derive { + eprintln!("{}", ts); + } + ts +} + +pub fn derive_der_sequence(s: synstructure::Structure) -> proc_macro2::TokenStream { + let ast = s.ast(); + + let container = match &ast.data { + Data::Struct(ds) => Container::from_datastruct(ds, ast, ContainerType::Sequence), + _ => panic!("Unsupported type, cannot derive"), + }; + + let debug_derive = ast.attrs.iter().any(|attr| { + attr.path + .is_ident(&Ident::new("debug_derive", Span::call_site())) + }); + let impl_tryfrom = container.gen_tryfrom(); + let impl_tagged = container.gen_tagged(); + let impl_checkconstraints = container.gen_checkconstraints(); + let impl_fromder = container.gen_fromder(); + let ts = s.gen_impl(quote! { + extern crate asn1_rs; + + #impl_tryfrom + #impl_tagged + #impl_checkconstraints + #impl_fromder + }); + if debug_derive { + eprintln!("{}", ts); + } + ts +} |