about summary refs log tree commit diff
path: root/src/bootstrap/parser.src
diff options
context:
space:
mode:
authorBaitinq <[email protected]>2025-06-05 00:08:00 +0200
committerBaitinq <[email protected]>2025-06-05 00:08:00 +0200
commit7371673ab581f2ab4db313dadf21c661ce0b7d87 (patch)
treecaf5fa7a73be8acc8ed4df0a4e45920b976ed72c /src/bootstrap/parser.src
parentstd: Add assert impl (diff)
downloadpry-lang-7371673ab581f2ab4db313dadf21c661ce0b7d87.tar.gz
pry-lang-7371673ab581f2ab4db313dadf21c661ce0b7d87.tar.bz2
pry-lang-7371673ab581f2ab4db313dadf21c661ce0b7d87.zip
Bootstrap: Codegen: Continue implementation
Diffstat (limited to 'src/bootstrap/parser.src')
-rw-r--r--src/bootstrap/parser.src13
1 files changed, 6 insertions, 7 deletions
diff --git a/src/bootstrap/parser.src b/src/bootstrap/parser.src
index 6b9bbaf..9ee53f6 100644
--- a/src/bootstrap/parser.src
+++ b/src/bootstrap/parser.src
@@ -50,7 +50,7 @@ let UNARY_EXPRESSION_TYPE_MINUS = 1;
 let UNARY_EXPRESSION_TYPE_STAR = 2;
 
 let NODE_PROGRAM_DATA = struct {
-    statements: *Node,
+    statements: **Node,
     statements_len: i64,
 };
 
@@ -78,13 +78,13 @@ let NODE_FUNCTION_CALL_STATEMENT_DATA = struct {
 
 let NODE_IF_STATEMENT_DATA = struct {
     condition: *Node,
-    statements: *Node,
+    statements: **Node,
     statements_len: i64,
 };
 
 let NODE_WHILE_STATEMENT_DATA = struct {
     condition: *Node,
-    statements: *Node,
+    statements: **Node,
     statements_len: i64,
 };
 
@@ -138,7 +138,7 @@ let NODE_PRIMARY_EXPRESSION_IDENTIFIER_DATA = struct {
 };
 
 let NODE_FUNCTION_DEFINITION_DATA = struct {
-    statements: *Node,
+    statements: **Node,
     statements_len: i64,
     parameters: *Node,
     parameters_len: i64,
@@ -325,7 +325,7 @@ let parse_statement = (p: *parser) => *Node {
 
 /* Program ::= Statement+ */
 let parse_program = (p: *parser) => *Node {
-	let nodes = cast(*Node, arena_alloc((*p).arena, sizeof(Node) * 1000));
+	let nodes = cast(**Node, arena_alloc((*p).arena, sizeof(*Node) * 1000));
 
 	let i = 0;
 	while (*p).offset < (*p).tokens_len {
@@ -334,8 +334,7 @@ let parse_program = (p: *parser) => *Node {
 			println("ERROR! Null node %d", (*p).offset);
 			return s;
 		};
-		println("PARSE 1 stmt");
-		(*(nodes + cast(*Node, i))) = s;
+		(*(nodes + cast(**Node, i))) = s;
 		i = i + 1;
 	};