aboutsummaryrefslogtreecommitdiffhomepage
path: root/src
diff options
context:
space:
mode:
authornsfisis <nsfisis@gmail.com>2025-09-15 12:35:47 +0900
committernsfisis <nsfisis@gmail.com>2025-09-15 13:00:31 +0900
commitc12aa625ce7fed32f1416b9c711ea9d6e960e002 (patch)
treeedcd116017cb84fa07189e8c650c34206cb275a4 /src
parent93c25fde8b26da97a7984c48cbc9f0f7f6037483 (diff)
downloadducc-c12aa625ce7fed32f1416b9c711ea9d6e960e002.tar.gz
ducc-c12aa625ce7fed32f1416b9c711ea9d6e960e002.tar.zst
ducc-c12aa625ce7fed32f1416b9c711ea9d6e960e002.zip
fix: issue where enumeration cannot be referenced until enum definition completes
Diffstat (limited to 'src')
-rw-r--r--src/parse.c12
1 files changed, 8 insertions, 4 deletions
diff --git a/src/parse.c b/src/parse.c
index 99db2b5..e9e9312 100644
--- a/src/parse.c
+++ b/src/parse.c
@@ -1453,9 +1453,14 @@ static AstNode* parse_enum_member(Parser* p) {
return member;
}
-static AstNode* parse_enum_members(Parser* p) {
+static void parse_enum_members(Parser* p, int enum_idx) {
int next_value = 0;
AstNode* list = ast_new_list(16);
+
+ if (!p->enums->node_items[enum_idx].node_members) {
+ p->enums->node_items[enum_idx].node_members = list;
+ }
+
while (peek_token(p)->kind != TokenKind_brace_r) {
AstNode* member = parse_enum_member(p);
@@ -1469,11 +1474,11 @@ static AstNode* parse_enum_members(Parser* p) {
++next_value;
ast_append(list, member);
+
if (!consume_token_if(p, TokenKind_comma)) {
break;
}
}
- return list;
}
void parse_typedef_decl(Parser* p, AstNode* decls) {
@@ -1673,9 +1678,8 @@ static Type* parse_enum_specifier(Parser* p) {
enum_idx = p->enums->node_len - 1;
}
- AstNode* members = parse_enum_members(p);
+ parse_enum_members(p, enum_idx);
expect(p, TokenKind_brace_r);
- p->enums->node_items[enum_idx].node_members = members;
Type* ty = type_new(TypeKind_enum);
ty->ref.defs = p->enums;