diff options
| author | Baitinq <[email protected]> | 2025-05-30 23:05:09 +0200 |
|---|---|---|
| committer | Baitinq <[email protected]> | 2025-05-30 23:05:09 +0200 |
| commit | fbc474a0c619df6bd334d5cde1987f820840c5f3 (patch) | |
| tree | 5e5662dc5463e71574265e230748fd23e4a69891 /src | |
| parent | Feature: Support structs as pointers (diff) | |
| download | interpreter-fbc474a0c619df6bd334d5cde1987f820840c5f3.tar.gz interpreter-fbc474a0c619df6bd334d5cde1987f820840c5f3.tar.bz2 interpreter-fbc474a0c619df6bd334d5cde1987f820840c5f3.zip | |
Feature: Support recursive structs
Diffstat (limited to 'src')
| -rw-r--r-- | src/codegen.zig | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/src/codegen.zig b/src/codegen.zig index b60ad95..9be065e 100644 --- a/src/codegen.zig +++ b/src/codegen.zig @@ -727,6 +727,17 @@ pub const CodeGen = struct { .STRUCT_TYPE => |t| { const struct_type = llvm.LLVMStructCreateNamed(self.llvm_context, try std.fmt.allocPrintZ(self.arena, "{s}", .{name.?})); + // Needed for recursive structs + if (name != null) { + try self.environment.add_variable(name.?, try self.create_variable(.{ + .value = null, + .type = struct_type, + .stack_level = null, + .node = expression, + .node_type = expression, + })); + } + var llvm_types = std.ArrayList(llvm.LLVMTypeRef).init(self.arena); for (t.fields) |field| { |