diff options
| author | Mel <einebeere@gmail.com> | 2021-10-24 18:26:01 +0200 |
|---|---|---|
| committer | Mel <einebeere@gmail.com> | 2021-10-24 18:26:01 +0200 |
| commit | af34b3030a46805f42f04341f1ffb20d92fbb7ce (patch) | |
| tree | affed084f5d1d31921b44142428f18d725ed2cea /src/parse/ast/expression.rs | |
| parent | 73c4808c44f75b7d6546f00f70779fcbf8e28754 (diff) | |
| download | rabbithole-af34b3030a46805f42f04341f1ffb20d92fbb7ce.tar.zst rabbithole-af34b3030a46805f42f04341f1ffb20d92fbb7ce.zip | |
Array literals and array access
Diffstat (limited to 'src/parse/ast/expression.rs')
| -rw-r--r-- | src/parse/ast/expression.rs | 20 |
1 files changed, 14 insertions, 6 deletions
diff --git a/src/parse/ast/expression.rs b/src/parse/ast/expression.rs index 1eec69d..b2b9678 100644 --- a/src/parse/ast/expression.rs +++ b/src/parse/ast/expression.rs @@ -1,8 +1,8 @@ use std::fmt::{self, Display, Formatter}; use super::nodes::{ - ArrayAccessNode, BinaryOperator, BlockNode, CallNode, FnNode, Identifier, IfNode, Literal, - LoopNode, MemberAccessNode, UnaryOperator, + ArrayAccessNode, ArrayNode, BinaryOperator, BlockNode, CallNode, FnNode, Identifier, IfNode, + LoopNode, MemberAccessNode, SimpleLiteral, UnaryOperator, }; #[derive(Debug, Clone)] @@ -21,10 +21,11 @@ pub enum Expression { MemberAccess(Box<MemberAccessNode>), Group(Box<Expression>), Block(Box<BlockNode>), - Fn(Box<FnNode>), If(Box<IfNode>), Loop(Box<LoopNode>), - Literal(Literal), + FnLiteral(Box<FnNode>), + ArrayLiteral(ArrayNode), + SimpleLiteral(SimpleLiteral), Identifier(Identifier), } @@ -81,7 +82,7 @@ impl Expression { Expression::Block(block) => { Self::block_fmt(f, block, depth + 1)?; } - Expression::Fn(node) => { + Expression::FnLiteral(node) => { write!(f, "{}Fn (", pad)?; // Write self receiver @@ -107,7 +108,14 @@ impl Expression { )?; Self::block_fmt(f, &node.body, depth + 1)?; } - Expression::Literal(literal) => { + Expression::ArrayLiteral(node) => { + writeln!(f, "{}Array Literal:", pad)?; + for (i, c) in node.elements.iter().enumerate() { + writeln!(f, "{}- Element {}:", pad, i)?; + c.nested_fmt(f, depth + 1)?; + } + } + Expression::SimpleLiteral(literal) => { writeln!(f, "{}Literal: {:?}", pad, literal)?; } Expression::Identifier(identifier) => { |
