diff options
| author | nsfisis <nsfisis@gmail.com> | 2026-02-07 15:35:57 +0900 |
|---|---|---|
| committer | nsfisis <nsfisis@gmail.com> | 2026-02-07 17:37:23 +0900 |
| commit | 55d624106b3abedfa13d8ea7c2edeef0d0da77a2 (patch) | |
| tree | 8ed2fe51db027404d64ae3c93fedd2b3deefec79 | |
| parent | f684a1f964d2761a4721497973023fa82923f121 (diff) | |
| download | ducc-55d624106b3abedfa13d8ea7c2edeef0d0da77a2.tar.gz ducc-55d624106b3abedfa13d8ea7c2edeef0d0da77a2.tar.zst ducc-55d624106b3abedfa13d8ea7c2edeef0d0da77a2.zip | |
feat: support unions in initializer
| -rw-r--r-- | src/parse.c | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/src/parse.c b/src/parse.c index b1a1d9b..55cac2b 100644 --- a/src/parse.c +++ b/src/parse.c @@ -2815,6 +2815,14 @@ static void do_eval_init_expr(InitData* buf, AstNode* expr, Type* ty) { } int total = type_sizeof(ty); initdata_append_zeros(buf, total - offset); // padding + } else if (ty->kind == TypeKind_union) { + AstNode* def = &ty->ref.defs->as.list->items[ty->ref.index]; + AstNode* members = def->as.union_def->members; + AstNode* member = &members->as.list->items[0]; + do_eval_init_expr(buf, &list->as.list->items[0], member->ty); + int member_size = type_sizeof(member->ty); + int total = type_sizeof(ty); + initdata_append_zeros(buf, total - member_size); // padding } else { unimplemented(); } |
