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
Formats the value using the given formatter. Read more
This method tests for self
and other
values to be equal, and is used by ==
. Read more
This method tests for !=
.
Feeds this value into the given [Hasher
]. Read more
Feeds a slice of this type into the given [Hasher
]. Read more
Performs copy-assignment from source
. Read more
Write self
to the given TokenStream
. Read more
Convert self
directly into a TokenStream
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
[+]
[+]
type Error = <U as TryFrom<T>>::Error
🔬 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
)
[+]
[−]
🔬 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. (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