Enum cairo_lang_syntax::node::ast::Expr
source · pub enum Expr {
Show 19 variants
Path(ExprPath),
Literal(TerminalLiteralNumber),
ShortString(TerminalShortString),
False(TerminalFalse),
True(TerminalTrue),
Parenthesized(ExprParenthesized),
Unary(ExprUnary),
Binary(ExprBinary),
Tuple(ExprTuple),
FunctionCall(ExprFunctionCall),
StructCtorCall(ExprStructCtorCall),
Block(ExprBlock),
Match(ExprMatch),
If(ExprIf),
Loop(ExprLoop),
ErrorPropagate(ExprErrorPropagate),
FieldInitShorthand(ExprFieldInitShorthand),
Indexed(ExprIndexed),
Missing(ExprMissing),
}
Variants§
Path(ExprPath)
Literal(TerminalLiteralNumber)
ShortString(TerminalShortString)
False(TerminalFalse)
True(TerminalTrue)
Parenthesized(ExprParenthesized)
Unary(ExprUnary)
Binary(ExprBinary)
Tuple(ExprTuple)
FunctionCall(ExprFunctionCall)
StructCtorCall(ExprStructCtorCall)
Block(ExprBlock)
Match(ExprMatch)
If(ExprIf)
Loop(ExprLoop)
ErrorPropagate(ExprErrorPropagate)
FieldInitShorthand(ExprFieldInitShorthand)
Indexed(ExprIndexed)
Missing(ExprMissing)
Trait Implementations§
source§impl PartialEq<Expr> for Expr
impl PartialEq<Expr> for Expr
source§impl TypedSyntaxNode for Expr
impl TypedSyntaxNode for Expr
source§const OPTIONAL_KIND: Option<SyntaxKind> = None
const OPTIONAL_KIND: Option<SyntaxKind> = None
The relevant SyntaxKind. None for enums.
type StablePtr = ExprPtr
type Green = ExprGreen
fn missing(db: &dyn SyntaxGroup) -> Self::Green
fn from_syntax_node(db: &dyn SyntaxGroup, node: SyntaxNode) -> Self
fn as_syntax_node(&self) -> SyntaxNode
fn from_ptr( db: &dyn SyntaxGroup, root: &SyntaxFile, ptr: Self::StablePtr ) -> Self
fn stable_ptr(&self) -> Self::StablePtr
impl Eq for Expr
impl StructuralEq for Expr
impl StructuralPartialEq for Expr
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§
source§impl<Q, K> Equivalent<K> for Qwhere
Q: Eq + ?Sized,
K: Borrow<Q> + ?Sized,
impl<Q, K> Equivalent<K> for Qwhere Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,
source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key
and return true
if they are equal.