pub struct VariantInfo<'a> {
    pub prefix: Option<&'a Ident>,
    /* private fields */
}Expand description
A wrapper around a syn::DeriveInput’s variant which provides utilities
for destructuring Variants with match expressions.
Fields§
§prefix: Option<&'a Ident>Implementations§
Source§impl<'a> VariantInfo<'a>
 
impl<'a> VariantInfo<'a>
Sourcepub fn bindings(&self) -> &[BindingInfo<'a>]
 
pub fn bindings(&self) -> &[BindingInfo<'a>]
Returns a slice of the bindings in this Variant.
Sourcepub fn bindings_mut(&mut self) -> &mut [BindingInfo<'a>]
 
pub fn bindings_mut(&mut self) -> &mut [BindingInfo<'a>]
Returns a mut slice of the bindings in this Variant.
Sourcepub fn ast(&self) -> VariantAst<'a>
 
pub fn ast(&self) -> VariantAst<'a>
Returns a VariantAst object which contains references to the
underlying syn AST node which this Variant was created from.
Sourcepub fn omitted_bindings(&self) -> bool
 
pub fn omitted_bindings(&self) -> bool
True if any bindings were omitted due to a filter call.
Sourcepub fn pat(&self) -> TokenStream
 
pub fn pat(&self) -> TokenStream
Generates the match-arm pattern which could be used to match against this Variant.
§Example
let di: syn::DeriveInput = syn::parse_quote! {
    enum A {
        B(i32, i32),
        C(u32),
    }
};
let s = Structure::new(&di);
assert_eq!(
    s.variants()[0].pat().to_string(),
    quote!{
        A::B(ref __binding_0, ref __binding_1,)
    }.to_string()
);Sourcepub fn construct<F, T>(&self, func: F) -> TokenStream
 
pub fn construct<F, T>(&self, func: F) -> TokenStream
Generates the token stream required to construct the current variant.
The init array initializes each of the fields in the order they are
written in variant.ast().fields.
§Example
let di: syn::DeriveInput = syn::parse_quote! {
    enum A {
        B(usize, usize),
        C{ v: usize },
    }
};
let s = Structure::new(&di);
assert_eq!(
    s.variants()[0].construct(|_, i| quote!(#i)).to_string(),
    quote!{
        A::B(0usize, 1usize,)
    }.to_string()
);
assert_eq!(
    s.variants()[1].construct(|_, i| quote!(#i)).to_string(),
    quote!{
        A::C{ v: 0usize, }
    }.to_string()
);Sourcepub fn each<F, R>(&self, f: F) -> TokenStream
 
pub fn each<F, R>(&self, f: F) -> TokenStream
Runs the passed-in function once for each bound field, passing in a BindingInfo.
and generating a match arm which evaluates the returned tokens.
This method will ignore fields which are ignored through the filter
method.
§Example
let di: syn::DeriveInput = syn::parse_quote! {
    enum A {
        B(i32, i32),
        C(u32),
    }
};
let s = Structure::new(&di);
assert_eq!(
    s.variants()[0].each(|bi| quote!(println!("{:?}", #bi))).to_string(),
    quote!{
        A::B(ref __binding_0, ref __binding_1,) => {
            { println!("{:?}", __binding_0) }
            { println!("{:?}", __binding_1) }
        }
    }.to_string()
);Sourcepub fn fold<F, I, R>(&self, init: I, f: F) -> TokenStream
 
pub fn fold<F, I, R>(&self, init: I, f: F) -> TokenStream
Runs the passed-in function once for each bound field, passing in the
result of the previous call, and a BindingInfo. generating a match
arm which evaluates to the resulting tokens.
This method will ignore fields which are ignored through the filter
method.
§Example
let di: syn::DeriveInput = syn::parse_quote! {
    enum A {
        B(i32, i32),
        C(u32),
    }
};
let s = Structure::new(&di);
assert_eq!(
    s.variants()[0].fold(quote!(0), |acc, bi| quote!(#acc + #bi)).to_string(),
    quote!{
        A::B(ref __binding_0, ref __binding_1,) => {
            0 + __binding_0 + __binding_1
        }
    }.to_string()
);Sourcepub fn filter<F>(&mut self, f: F) -> &mut Self
 
pub fn filter<F>(&mut self, f: F) -> &mut Self
Filter the bindings created by this Variant object. This has 2 effects:
- 
The bindings will no longer appear in match arms generated by methods on this Variantor its subobjects.
- 
Impl blocks created with the bound_implorunsafe_bound_implmethod only consider type parameters referenced in the types of non-filtered fields.
§Example
let di: syn::DeriveInput = syn::parse_quote! {
    enum A {
        B{ a: i32, b: i32 },
        C{ a: u32 },
    }
};
let mut s = Structure::new(&di);
s.variants_mut()[0].filter(|bi| {
    bi.ast().ident == Some(quote::format_ident!("b"))
});
assert_eq!(
    s.each(|bi| quote!(println!("{:?}", #bi))).to_string(),
    quote!{
        A::B{ b: ref __binding_1, .. } => {
            { println!("{:?}", __binding_1) }
        }
        A::C{ a: ref __binding_0, } => {
            { println!("{:?}", __binding_0) }
        }
    }.to_string()
);Sourcepub fn drain_filter<F>(&mut self, f: F) -> Self
 
pub fn drain_filter<F>(&mut self, f: F) -> Self
Iterates all the bindings of this Variant object and uses a closure to determine if a
binding should be removed. If the closure returns true the binding is removed from the
variant. If the closure returns false, the binding remains in the variant.
All the removed bindings are moved to a new Variant object which is otherwise identical
to the current one. To understand the effects of removing a binding from a variant check
the VariantInfo::filter documentation.
§Example
let di: syn::DeriveInput = syn::parse_quote! {
    enum A {
        B{ a: i32, b: i32 },
        C{ a: u32 },
    }
};
let mut s = Structure::new(&di);
let mut with_b = &mut s.variants_mut()[0];
let with_a = with_b.drain_filter(|bi| {
    bi.ast().ident == Some(quote::format_ident!("a"))
});
assert_eq!(
    with_a.each(|bi| quote!(println!("{:?}", #bi))).to_string(),
    quote!{
        A::B{ a: ref __binding_0, .. } => {
            { println!("{:?}", __binding_0) }
        }
    }.to_string()
);
assert_eq!(
    with_b.each(|bi| quote!(println!("{:?}", #bi))).to_string(),
    quote!{
        A::B{ b: ref __binding_1, .. } => {
            { println!("{:?}", __binding_1) }
        }
    }.to_string()
);Sourcepub fn remove_binding(&mut self, idx: usize) -> &mut Self
 
pub fn remove_binding(&mut self, idx: usize) -> &mut Self
Sourcepub fn bind_with<F>(&mut self, f: F) -> &mut Self
 
pub fn bind_with<F>(&mut self, f: F) -> &mut Self
Updates the BindStyle for each of the passed-in fields by calling the
passed-in function for each BindingInfo.
§Example
let di: syn::DeriveInput = syn::parse_quote! {
    enum A {
        B(i32, i32),
        C(u32),
    }
};
let mut s = Structure::new(&di);
s.variants_mut()[0].bind_with(|bi| BindStyle::RefMut);
assert_eq!(
    s.each(|bi| quote!(println!("{:?}", #bi))).to_string(),
    quote!{
        A::B(ref mut __binding_0, ref mut __binding_1,) => {
            { println!("{:?}", __binding_0) }
            { println!("{:?}", __binding_1) }
        }
        A::C(ref __binding_0,) => {
            { println!("{:?}", __binding_0) }
        }
    }.to_string()
);Sourcepub fn binding_name<F>(&mut self, f: F) -> &mut Self
 
pub fn binding_name<F>(&mut self, f: F) -> &mut Self
Updates the binding name for each fo the passed-in fields by calling the
passed-in function for each BindingInfo.
The function will be called with the BindingInfo and its index in the
enclosing variant.
The default name is __binding_{} where {} is replaced with an
increasing number.
§Example
let di: syn::DeriveInput = syn::parse_quote! {
    enum A {
        B{ a: i32, b: i32 },
        C{ a: u32 },
    }
};
let mut s = Structure::new(&di);
s.variants_mut()[0].binding_name(|bi, i| bi.ident.clone().unwrap());
assert_eq!(
    s.each(|bi| quote!(println!("{:?}", #bi))).to_string(),
    quote!{
        A::B{ a: ref a, b: ref b, } => {
            { println!("{:?}", a) }
            { println!("{:?}", b) }
        }
        A::C{ a: ref __binding_0, } => {
            { println!("{:?}", __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 VariantInfo<'a>
 
impl<'a> Clone for VariantInfo<'a>
Source§fn clone(&self) -> VariantInfo<'a>
 
fn clone(&self) -> VariantInfo<'a>
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
 
fn clone_from(&mut self, source: &Self)
source. Read more