Enum syntax::ast::PatKind [−][src]
pub enum PatKind {
Wild,
Ident(BindingMode, Ident, Option<P<Pat>>),
Struct(Path, Vec<Spanned<FieldPat>>, bool),
TupleStruct(Path, Vec<P<Pat>>, Option<usize>),
Path(Option<QSelf>, Path),
Tuple(Vec<P<Pat>>, Option<usize>),
Box(P<Pat>),
Ref(P<Pat>, Mutability),
Lit(P<Expr>),
Range(P<Expr>, P<Expr>, RangeEnd),
Slice(Vec<P<Pat>>, Option<P<Pat>>, Vec<P<Pat>>),
Paren(P<Pat>),
Mac(Mac),
}Variants
WildRepresents a wildcard pattern (_)
Ident(BindingMode, Ident, Option<P<Pat>>)A PatKind::Ident may either be a new bound variable (ref mut binding @ OPT_SUBPATTERN),
or a unit struct/variant pattern, or a const pattern (in the last two cases the third
field must be None). Disambiguation cannot be done with parser alone, so it happens
during name resolution.
Struct(Path, Vec<Spanned<FieldPat>>, bool)A struct or struct variant pattern, e.g. Variant {x, y, ..}.
The bool is true in the presence of a ...
TupleStruct(Path, Vec<P<Pat>>, Option<usize>)A tuple struct/variant pattern Variant(x, y, .., z).
If the .. pattern fragment is present, then Option<usize> denotes its position.
0 <= position <= subpats.len()
Path(Option<QSelf>, Path)A possibly qualified path pattern.
Unqualified path patterns A::B::C can legally refer to variants, structs, constants
or associated constants. Qualified path patterns <A>::B::C/<A as Trait>::B::C can
only legally refer to associated constants.
Tuple(Vec<P<Pat>>, Option<usize>)A tuple pattern (a, b).
If the .. pattern fragment is present, then Option<usize> denotes its position.
0 <= position <= subpats.len()
Box(P<Pat>)A box pattern
Ref(P<Pat>, Mutability)A reference pattern, e.g. &mut (a, b)
Lit(P<Expr>)A literal
Range(P<Expr>, P<Expr>, RangeEnd)A range pattern, e.g. 1...2, 1..=2 or 1..2
Slice(Vec<P<Pat>>, Option<P<Pat>>, Vec<P<Pat>>)[a, b, ..i, y, z] is represented as:
PatKind::Slice(box [a, b], Some(i), box [y, z])
Paren(P<Pat>)Parentheses in patters used for grouping, i.e. (PAT).
Mac(Mac)A macro pattern; pre-expansion
Trait Implementations
impl Clone for PatKind[src]
impl Clone for PatKindfn clone(&self) -> PatKind[src]
fn clone(&self) -> PatKindReturns a copy of the value. Read more
fn clone_from(&mut self, source: &Self)1.0.0[src]
fn clone_from(&mut self, source: &Self)Performs copy-assignment from source. Read more
impl PartialEq for PatKind[src]
impl PartialEq for PatKindfn eq(&self, other: &PatKind) -> bool[src]
fn eq(&self, other: &PatKind) -> boolThis method tests for self and other values to be equal, and is used by ==. Read more
fn ne(&self, other: &PatKind) -> bool[src]
fn ne(&self, other: &PatKind) -> boolThis method tests for !=.
impl Eq for PatKind[src]
impl Eq for PatKindimpl Encodable for PatKind[src]
impl Encodable for PatKindimpl Decodable for PatKind[src]
impl Decodable for PatKindimpl Hash for PatKind[src]
impl Hash for PatKindfn hash<__H: Hasher>(&self, state: &mut __H)[src]
fn hash<__H: Hasher>(&self, state: &mut __H)Feeds this value into the given [Hasher]. Read more
fn hash_slice<H>(data: &[Self], state: &mut H) where
H: Hasher, 1.3.0[src]
fn hash_slice<H>(data: &[Self], state: &mut H) where
H: Hasher, Feeds a slice of this type into the given [Hasher]. Read more
impl Debug for PatKind[src]
impl Debug for PatKind