pub enum Pat {
Show 16 variants
Box(PatBox),
Ident(PatIdent),
Lit(PatLit),
Macro(PatMacro),
Or(PatOr),
Path(PatPath),
Range(PatRange),
Reference(PatReference),
Rest(PatRest),
Slice(PatSlice),
Struct(PatStruct),
Tuple(PatTuple),
TupleStruct(PatTupleStruct),
Type(PatType),
Verbatim(TokenStream),
Wild(PatWild),
// some variants omitted
}
Expand description
A pattern in a local binding, function signature, match expression, or various other places.
This type is available only if Syn is built with the "full"
feature.
Syntax tree enum
This type is a syntax tree enum.
Variants
Box(PatBox)
A box pattern: box v
.
Ident(PatIdent)
A pattern that binds a new variable: ref mut binding @ SUBPATTERN
.
Lit(PatLit)
A literal pattern: 0
.
This holds an Expr
rather than a Lit
because negative numbers
are represented as an Expr::Unary
.
Macro(PatMacro)
A macro in pattern position.
Or(PatOr)
A pattern that matches any one of a set of cases.
Path(PatPath)
A path pattern like Color::Red
, optionally qualified with a
self-type.
Unqualified path patterns can legally refer to variants, structs,
constants or associated constants. Qualified path patterns like
<A>::B::C
and <A as Trait>::B::C
can only legally refer to
associated constants.
Range(PatRange)
A range pattern: 1..=2
.
Reference(PatReference)
A reference pattern: &mut var
.
Rest(PatRest)
The dots in a tuple or slice pattern: [0, 1, ..]
Slice(PatSlice)
A dynamically sized slice pattern: [a, b, ref i @ .., y, z]
.
Struct(PatStruct)
A struct or struct variant pattern: Variant { x, y, .. }
.
Tuple(PatTuple)
A tuple pattern: (a, b)
.
TupleStruct(PatTupleStruct)
A tuple struct or tuple variant pattern: Variant(x, y, .., z)
.
Type(PatType)
A type ascription pattern: foo: f64
.
Verbatim(TokenStream)
Tokens in pattern position not interpreted by Syn.
Wild(PatWild)
A pattern that matches any value: _
.
Trait Implementations
Performs the conversion.
Performs the conversion.
Auto Trait Implementations
impl RefUnwindSafe for Pat
impl UnwindSafe for Pat
Blanket Implementations
Mutably borrows from an owned value. 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