Enum syn::Expr [−][src]
A Rust expression.
This type is available only if Syn is built with the "derive"
or "full"
feature, but most of the variants are not available unless “full” is enabled.
Syntax tree enums
This type is a syntax tree enum. In Syn this and other syntax tree enums are designed to be traversed using the following rebinding idiom.
let expr: Expr = /* ... */; match expr { Expr::MethodCall(expr) => { /* ... */ } Expr::Cast(expr) => { /* ... */ } Expr::If(expr) => { /* ... */ } /* ... */
We begin with a variable expr
of type Expr
that has no fields
(because it is an enum), and by matching on it and rebinding a variable
with the same name expr
we effectively imbue our variable with all of
the data fields provided by the variant that it turned out to be. So for
example above if we ended up in the MethodCall
case then we get to use
expr.receiver
, expr.args
etc; if we ended up in the If
case we get
to use expr.cond
, expr.then_branch
, expr.else_branch
.
This approach avoids repeating the variant names twice on every line.
// Repetitive; recommend not doing this. match expr { Expr::MethodCall(ExprMethodCall { method, args, .. }) => {
In general, the name to which a syntax tree enum variant is bound should be a suitable name for the complete syntax tree enum type.
// Binding is called `base` which is the name I would use if I were // assigning `*discriminant.base` without an `if let`. if let Expr::Tuple(base) = *discriminant.base {
A sign that you may not be choosing the right variable names is if you
see names getting repeated in your code, like accessing
receiver.receiver
or pat.pat
or cond.cond
.
Variants
Array(ExprArray)
A slice literal expression: [a, b, c, d]
.
Assign(ExprAssign)
An assignment expression: a = compute()
.
AssignOp(ExprAssignOp)
A compound assignment expression: counter += 1
.
Async(ExprAsync)
An async block: async { ... }
.
Await(ExprAwait)
An await expression: fut.await
.
Binary(ExprBinary)
A binary operation: a + b
, a * b
.
Block(ExprBlock)
A blocked scope: { ... }
.
Box(ExprBox)
A box expression: box f
.
Break(ExprBreak)
A break
, with an optional label to break and an optional
expression.
Call(ExprCall)
A function call expression: invoke(a, b)
.
Cast(ExprCast)
A cast expression: foo as f64
.
Closure(ExprClosure)
A closure expression: |a, b| a + b
.
Continue(ExprContinue)
A continue
, with an optional label.
Field(ExprField)
Access of a named struct field (obj.k
) or unnamed tuple struct
field (obj.0
).
ForLoop(ExprForLoop)
A for loop: for pat in expr { ... }
.
Group(ExprGroup)
An expression contained within invisible delimiters.
This variant is important for faithfully representing the precedence
of expressions and is related to None
-delimited spans in a
TokenStream
.
If(ExprIf)
An if
expression with an optional else
block: if expr { ... } else { ... }
.
The else
branch expression may only be an If
or Block
expression, not any of the other types of expression.
Index(ExprIndex)
A square bracketed indexing expression: vector[2]
.
Let(ExprLet)
A let
guard: let Some(x) = opt
.
Lit(ExprLit)
A literal in place of an expression: 1
, "foo"
.
Loop(ExprLoop)
Conditionless loop: loop { ... }
.
Macro(ExprMacro)
A macro invocation expression: format!("{}", q)
.
Match(ExprMatch)
A match
expression: match n { Some(n) => {}, None => {} }
.
MethodCall(ExprMethodCall)
A method call expression: x.foo::<T>(a, b)
.
Paren(ExprParen)
A parenthesized expression: (a + b)
.
Path(ExprPath)
A path like std::mem::replace
possibly containing generic
parameters and a qualified self-type.
A plain identifier like x
is a path of length 1.
Range(ExprRange)
A range expression: 1..2
, 1..
, ..2
, 1..=2
, ..=2
.
Reference(ExprReference)
A referencing operation: &a
or &mut a
.
Repeat(ExprRepeat)
An array literal constructed from one repeated element: [0u8; N]
.
Return(ExprReturn)
A return
, with an optional value to be returned.
Struct(ExprStruct)
A struct literal expression: Point { x: 1, y: 1 }
.
The rest
provides the value of the remaining fields as in S { a: 1, b: 1, ..rest }
.
Try(ExprTry)
A try-expression: expr?
.
TryBlock(ExprTryBlock)
A try block: try { ... }
.
Tuple(ExprTuple)
A tuple expression: (a, b, c, d)
.
Type(ExprType)
A type ascription expression: foo: f64
.
Unary(ExprUnary)
A unary operation: !x
, *x
.
Unsafe(ExprUnsafe)
An unsafe block: unsafe { ... }
.
Verbatim(TokenStream)
Tokens in expression position not interpreted by Syn.
While(ExprWhile)
A while loop: while expr { ... }
.
Yield(ExprYield)
A yield expression: yield expr
.
Trait Implementations
impl Clone for Expr
[src]
fn clone(&self) -> Self
[src]
pub fn clone_from(&mut self, source: &Self)
1.0.0[src]
impl Debug for Expr
[src]
impl Eq for Expr
[src]
impl From<ExprArray> for Expr
[src]
impl From<ExprAssign> for Expr
[src]
fn from(e: ExprAssign) -> Expr
[src]
impl From<ExprAssignOp> for Expr
[src]
fn from(e: ExprAssignOp) -> Expr
[src]
impl From<ExprAsync> for Expr
[src]
impl From<ExprAwait> for Expr
[src]
impl From<ExprBinary> for Expr
[src]
fn from(e: ExprBinary) -> Expr
[src]
impl From<ExprBlock> for Expr
[src]
impl From<ExprBox> for Expr
[src]
impl From<ExprBreak> for Expr
[src]
impl From<ExprCall> for Expr
[src]
impl From<ExprCast> for Expr
[src]
impl From<ExprClosure> for Expr
[src]
fn from(e: ExprClosure) -> Expr
[src]
impl From<ExprContinue> for Expr
[src]
fn from(e: ExprContinue) -> Expr
[src]
impl From<ExprField> for Expr
[src]
impl From<ExprForLoop> for Expr
[src]
fn from(e: ExprForLoop) -> Expr
[src]
impl From<ExprGroup> for Expr
[src]
impl From<ExprIf> for Expr
[src]
impl From<ExprIndex> for Expr
[src]
impl From<ExprLet> for Expr
[src]
impl From<ExprLit> for Expr
[src]
impl From<ExprLoop> for Expr
[src]
impl From<ExprMacro> for Expr
[src]
impl From<ExprMatch> for Expr
[src]
impl From<ExprMethodCall> for Expr
[src]
fn from(e: ExprMethodCall) -> Expr
[src]
impl From<ExprParen> for Expr
[src]
impl From<ExprPath> for Expr
[src]
impl From<ExprRange> for Expr
[src]
impl From<ExprReference> for Expr
[src]
fn from(e: ExprReference) -> Expr
[src]
impl From<ExprRepeat> for Expr
[src]
fn from(e: ExprRepeat) -> Expr
[src]
impl From<ExprReturn> for Expr
[src]
fn from(e: ExprReturn) -> Expr
[src]
impl From<ExprStruct> for Expr
[src]
fn from(e: ExprStruct) -> Expr
[src]
impl From<ExprTry> for Expr
[src]
impl From<ExprTryBlock> for Expr
[src]
fn from(e: ExprTryBlock) -> Expr
[src]
impl From<ExprTuple> for Expr
[src]
impl From<ExprType> for Expr
[src]
impl From<ExprUnary> for Expr
[src]
impl From<ExprUnsafe> for Expr
[src]
fn from(e: ExprUnsafe) -> Expr
[src]
impl From<ExprWhile> for Expr
[src]
impl From<ExprYield> for Expr
[src]
impl Hash for Expr
[src]
fn hash<H>(&self, state: &mut H) where
H: Hasher,
[src]
H: Hasher,
pub fn hash_slice<H>(data: &[Self], state: &mut H) where
H: Hasher,
1.3.0[src]
H: Hasher,
impl Parse for Expr
[src]
fn parse(input: ParseStream<'_>) -> Result<Self>
[src]
impl PartialEq<Expr> for Expr
[src]
impl ToTokens for Expr
[src]
fn to_tokens(&self, tokens: &mut TokenStream)
[src]
pub fn to_token_stream(&self) -> TokenStream
[src]
pub fn into_token_stream(self) -> TokenStream
[src]
Auto Trait Implementations
impl RefUnwindSafe for Expr
impl !Send for Expr
impl !Sync for Expr
impl Unpin for Expr
impl UnwindSafe for Expr
Blanket Implementations
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
pub fn borrow_mut(&mut self) -> &mut T
[src]
impl<T> From<T> for T
[src]
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<T> Spanned for T where
T: Spanned + ?Sized,
[src]
T: Spanned + ?Sized,
impl<T> ToOwned for T where
T: Clone,
[src]
T: Clone,
type Owned = T
The resulting type after obtaining ownership.
pub fn to_owned(&self) -> T
[src]
pub fn clone_into(&self, target: &mut T)
[src]
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
pub fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,