pub enum Pat {
    Wild(PatWild),
    Ident(PatIdent),
    Struct(PatStruct),
    TupleStruct(PatTupleStruct),
    Path(PatPath),
    Tuple(PatTuple),
    Box(PatBox),
    Ref(PatRef),
    Lit(PatLit),
    Range(PatRange),
    Slice(PatSlice),
    Macro(PatMacro),
    Verbatim(PatVerbatim),
}A pattern in a local binding, function signature, match expression, or
various other places.
This type is available if Syn is built with the "full" feature.
This type is a syntax tree enum.
A pattern that matches any value: _.
This type is available if Syn is built with the "full" feature.
A pattern that binds a new variable: ref mut binding @ SUBPATTERN.
This type is available if Syn is built with the "full" feature.
A struct or struct variant pattern: Variant { x, y, .. }.
This type is available if Syn is built with the "full" feature.
A tuple struct or tuple variant pattern: Variant(x, y, .., z).
This type is available if Syn is built with the "full" feature.
A path pattern like Color::Red, optionally qualified with a
self-type.
Unquailfied path patterns can legally refer to variants, structs,
constants or associated constants. Quailfied path patterns like
<A>::B::C and <A as Trait>::B::C can only legally refer to
associated constants.
This type is available if Syn is built with the "full" feature.
A tuple pattern: (a, b).
This type is available if Syn is built with the "full" feature.
A box pattern: box v.
This type is available if Syn is built with the "full" feature.
A reference pattern: &mut (first, second).
This type is available if Syn is built with the "full" feature.
A literal pattern: 0.
This holds an Expr rather than a Lit because negative numbers
are represented as an Expr::Unary.
This type is available if Syn is built with the "full" feature.
A range pattern: 1..=2.
This type is available if Syn is built with the "full" feature.
A dynamically sized slice pattern: [a, b, i.., y, z].
This type is available if Syn is built with the "full" feature.
A macro in expression position.
This type is available if Syn is built with the "full" feature.
Tokens in pattern position not interpreted by Syn.
This type is available if Syn is built with the "full" feature.
A short name of the type being parsed. Read more
Performs copy-assignment from source. Read more
Convert self directly into a Tokens object. Read more
Returns a Span covering the complete contents of this syntax tree node, or [Span::call_site()] if this node is empty. Read more
Creates owned data from borrowed data, usually by cloning. Read more
🔬 This is a nightly-only experimental API.  (toowned_clone_into)
recently added
Uses borrowed data to replace owned data, usually by cloning. Read more
 
🔬 This is a nightly-only experimental API.  (try_from)
The type returned in the event of a conversion error.
🔬 This is a nightly-only experimental API.  (try_from)
 Immutably borrows from an owned value. Read more
🔬 This is a nightly-only experimental API.  (get_type_id)
this method will likely be replaced by an associated static
🔬 This is a nightly-only experimental API.  (try_from)
The type returned in the event of a conversion error.
🔬 This is a nightly-only experimental API.  (try_from)
 Mutably borrows from an owned value. Read more
🔬 This is a nightly-only experimental API.  (rustc_private)
this crate is being loaded from the sysroot, an unstable location; did you mean to load this crate from crates.io via Cargo.toml instead?
Create an error for a missing method specialization. Defaults to panicking with type, trait & method names. S is the encoder/decoder state type, T is the type being encoded/decoded, and the arguments are the names of the trait and method that should've been overridden. Read more