aboutsummaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
-rw-r--r--src/parse.c21
-rw-r--r--tests/struct_basics.sh17
2 files changed, 27 insertions, 11 deletions
diff --git a/src/parse.c b/src/parse.c
index 195a3b0..a9ecbe8 100644
--- a/src/parse.c
+++ b/src/parse.c
@@ -1515,24 +1515,23 @@ static AstNode* parse_member_declaration(Parser* p) {
expect(p, TokenKind_semicolon);
- if (decls->node_len != 1)
- unimplemented();
-
- AstNode* m = ast_new(AstNodeKind_struct_member);
- m->name = decls->node_items[0].name;
- m->ty = decls->node_items[0].ty;
- return m;
+ for (size_t i = 0; i < decls->node_len; i++) {
+ decls->node_items[i].kind = AstNodeKind_struct_member;
+ }
+ return decls;
}
// member-declaration-list:
// { member-declaration }+
static AstNode* parse_member_declaration_list(Parser* p) {
- AstNode* list = ast_new_list(4);
+ AstNode* members = ast_new_list(4);
while (peek_token(p)->kind != TokenKind_brace_r) {
- AstNode* member = parse_member_declaration(p);
- ast_append(list, member);
+ AstNode* decls = parse_member_declaration(p);
+ for (size_t i = 0; i < decls->node_len; i++) {
+ ast_append(members, &decls->node_items[i]);
+ }
}
- return list;
+ return members;
}
static AstNode* parse_enum_member(Parser* p) {
diff --git a/tests/struct_basics.sh b/tests/struct_basics.sh
index 2dff3bb..13a50a5 100644
--- a/tests/struct_basics.sh
+++ b/tests/struct_basics.sh
@@ -118,3 +118,20 @@ int main() {
return 0;
}
EOF
+
+test_exit_code 0 <<'EOF'
+#include <helpers.h>
+
+struct S {
+ int a, b;
+};
+
+struct T {
+ short *a, b, c[12];
+};
+
+int main() {
+ ASSERT_EQ(8, sizeof(struct S));
+ ASSERT_EQ(40, sizeof(struct T));
+}
+EOF