diff options
| author | nsfisis <nsfisis@gmail.com> | 2026-01-06 09:26:13 +0900 |
|---|---|---|
| committer | nsfisis <nsfisis@gmail.com> | 2026-01-06 09:26:13 +0900 |
| commit | b400b6bbdc526f5de357cb2657d79ea0343870bc (patch) | |
| tree | dc5faeb2f26221b16d7b0b65058ac9d8ce344d1d /src/parse.c | |
| parent | 4fd882beeee2ccbcc5b097cde9ba0e32b1b99a3e (diff) | |
| download | ducc-b400b6bbdc526f5de357cb2657d79ea0343870bc.tar.gz ducc-b400b6bbdc526f5de357cb2657d79ea0343870bc.tar.zst ducc-b400b6bbdc526f5de357cb2657d79ea0343870bc.zip | |
fix: for loop with multiple variable declarations
In this C code,
for (T v = expr1, u = expr2; ...; ...) { ... }
the "expr2" was silently discarded before.
Diffstat (limited to 'src/parse.c')
| -rw-r--r-- | src/parse.c | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/src/parse.c b/src/parse.c index 819c418..f336c0c 100644 --- a/src/parse.c +++ b/src/parse.c @@ -1166,7 +1166,15 @@ static AstNode* parse_for_stmt(Parser* p) { enter_scope(p); if (peek_token(p)->kind != TokenKind_semicolon) { if (is_type_token(p, peek_token(p))) { - init = parse_var_decl(p)->node_items[0].node_expr; + AstNode* decls = parse_var_decl(p); + AstNode* initializers = ast_new_list(1); + for (size_t i = 0; i < decls->node_len; i++) { + AstNode* initializer = decls->node_items[i].node_expr; + if (initializer) { + ast_append(initializers, initializer); + } + } + init = initializers; } else { init = parse_expr(p); expect(p, TokenKind_semicolon); |
