Struct synstructure::BindingInfo
source · Expand description
Information about a specific binding. This contains both an Ident
reference to the given field, and the syn &'a Field
descriptor for that
field.
This type supports quote::ToTokens
, so can be directly used within the
quote!
macro. It expands to a reference to the matched field.
Fields§
§binding: Ident
The name which this BindingInfo will bind to.
style: BindStyle
The type of binding which this BindingInfo will create.
Implementations§
source§impl<'a> BindingInfo<'a>
impl<'a> BindingInfo<'a>
sourcepub fn ast(&self) -> &'a Field
pub fn ast(&self) -> &'a Field
Returns a reference to the underlying syn
AST node which this
BindingInfo
references
sourcepub fn pat(&self) -> TokenStream
pub fn pat(&self) -> TokenStream
Generates the pattern fragment for this field binding.
Example
let di: syn::DeriveInput = syn::parse_quote! {
enum A {
B{ a: i32, b: i32 },
C(u32),
}
};
let s = Structure::new(&di);
assert_eq!(
s.variants()[0].bindings()[0].pat().to_string(),
quote! {
ref __binding_0
}.to_string()
);
sourcepub fn referenced_ty_params(&self) -> Vec<&'a Ident>
pub fn referenced_ty_params(&self) -> Vec<&'a Ident>
Returns a list of the type parameters which are referenced in this field’s type.
Caveat
If the field contains any macros in type position, all parameters will be considered bound. This is because we cannot determine which type parameters are bound by type macros.
Example
let di: syn::DeriveInput = syn::parse_quote! {
struct A<T, U> {
a: Option<T>,
b: U,
}
};
let mut s = Structure::new(&di);
assert_eq!(
s.variants()[0].bindings()[0].referenced_ty_params(),
&["e::format_ident!("T")]
);
Trait Implementations§
source§impl<'a> Clone for BindingInfo<'a>
impl<'a> Clone for BindingInfo<'a>
source§fn clone(&self) -> BindingInfo<'a>
fn clone(&self) -> BindingInfo<'a>
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read more