summary refs log tree commit diff
path: root/src
diff options
context:
space:
mode:
authorBaitinq <manuelpalenzuelamerino@gmail.com>2025-01-10 00:44:56 +0100
committerBaitinq <manuelpalenzuelamerino@gmail.com>2025-01-10 00:44:56 +0100
commit4044185cb87543089a201a6e440fba84df68983b (patch)
tree8294a4dbb53d83b1fd6050f54e20feec5967afbb /src
parentEvaluator: Implement variable declaration and definition and variable printing (diff)
downloadinterpreter-4044185cb87543089a201a6e440fba84df68983b.tar.gz
interpreter-4044185cb87543089a201a6e440fba84df68983b.tar.bz2
interpreter-4044185cb87543089a201a6e440fba84df68983b.zip
Misc: Support evaluating sequentially in REPL
Diffstat (limited to 'src')
-rw-r--r--src/main.zig18
-rw-r--r--src/parser.zig4
2 files changed, 12 insertions, 10 deletions
diff --git a/src/main.zig b/src/main.zig
index 4a0f9ef..e95bd48 100644
--- a/src/main.zig
+++ b/src/main.zig
@@ -17,6 +17,12 @@ pub fn main() !void {
         if (deinit_status == .leak) @panic("Memory leak detected!");
     }
 
+    const source_evaluator = try evaluator.Evaluator.init(allocator);
+    defer source_evaluator.deinit();
+
+    var arena = std.heap.ArenaAllocator.init(allocator);
+    defer arena.deinit();
+
     if (std.mem.eql(u8, path, "-i")) {
         while (true) {
             try stdout.print("> ", .{});
@@ -24,8 +30,8 @@ pub fn main() !void {
             const buf = try stdin.readUntilDelimiterAlloc(allocator, '\n', 1024);
             defer allocator.free(buf);
 
-            process_buf(buf, allocator) catch |err| {
-                try stdout.print("Error parsing line: {any}\n", .{err});
+            process_buf(buf, allocator, &arena, source_evaluator) catch |err| {
+                try stdout.print("Error processing line: {any}\n", .{err});
             };
         }
     } else {
@@ -33,11 +39,11 @@ pub fn main() !void {
         const file = try std.fs.cwd().openFile(path, .{});
         const buf = try file.readToEndAlloc(allocator, 1 * 1024 * 1024);
         defer allocator.free(buf);
-        try process_buf(buf, allocator);
+        try process_buf(buf, allocator, &arena, source_evaluator);
     }
 }
 
-fn process_buf(buf: []u8, allocator: std.mem.Allocator) !void {
+fn process_buf(buf: []u8, allocator: std.mem.Allocator, arena: *std.heap.ArenaAllocator, source_evaluator: *evaluator.Evaluator) !void {
     std.debug.print("Buf:\n{s}\n", .{buf});
 
     var token_list = std.ArrayList(tokenizer.Token).init(allocator);
@@ -52,14 +58,10 @@ fn process_buf(buf: []u8, allocator: std.mem.Allocator) !void {
         std.debug.print("{any}\n", .{token});
     }
 
-    var arena = std.heap.ArenaAllocator.init(allocator);
     const source_parser = try parser.Parser.init(token_list.items, arena.allocator());
-    defer arena.deinit();
     const ast = try source_parser.parse();
     std.debug.print("AST: {any}\n", .{ast});
 
-    const source_evaluator = try evaluator.Evaluator.init(allocator);
-    defer source_evaluator.deinit();
     const result = try source_evaluator.evaluate_ast(ast);
     std.debug.print("Evaluation result: {any}\n", .{result});
 }
diff --git a/src/parser.zig b/src/parser.zig
index 0db089f..d564924 100644
--- a/src/parser.zig
+++ b/src/parser.zig
@@ -103,7 +103,7 @@ pub const Parser = struct {
         return self.create_node(.{
             .VARIABLE_STATEMENT = .{
                 .is_declaration = is_declaration,
-                .name = identifier.IDENTIFIER,
+                .name = try self.allocator.dupe(u8, identifier.IDENTIFIER),
                 .expression = @constCast(expression),
             },
         });
@@ -141,7 +141,7 @@ pub const Parser = struct {
             .IDENTIFIER => |identifier_token| self.create_node(.{
                 .EXPRESSION = .{
                     .IDENTIFIER = .{
-                        .name = identifier_token,
+                        .name = try self.allocator.dupe(u8, identifier_token),
                     },
                 },
             }),