diff options
| author | nsfisis <nsfisis@gmail.com> | 2026-02-07 15:31:53 +0900 |
|---|---|---|
| committer | nsfisis <nsfisis@gmail.com> | 2026-02-07 15:31:53 +0900 |
| commit | e1042a6373773830297dfd5718938c12f21ae624 (patch) | |
| tree | ae7f55dbe65a6b6d8e6cf075c82156523b8189f6 /src/codegen.c | |
| parent | b90f2dcae69c04c50c56498e3c02a44d0d9da167 (diff) | |
| download | ducc-e1042a6373773830297dfd5718938c12f21ae624.tar.gz ducc-e1042a6373773830297dfd5718938c12f21ae624.tar.zst ducc-e1042a6373773830297dfd5718938c12f21ae624.zip | |
fix: codegen of switch fallthrough
Diffstat (limited to 'src/codegen.c')
| -rw-r--r-- | src/codegen.c | 5 |
1 files changed, 2 insertions, 3 deletions
diff --git a/src/codegen.c b/src/codegen.c index 4eb2042..5ac61ed 100644 --- a/src/codegen.c +++ b/src/codegen.c @@ -704,11 +704,10 @@ static bool codegen_switch_body(CodeGen* g, AstNode* stmt, int* case_values, int break; } } - codegen_stmt(g, stmt->as.case_label->body); - return false; + return codegen_switch_body(g, stmt->as.case_label->body, case_values, case_labels, n_cases); } else if (stmt->kind == AstNodeKind_default_label) { fprintf(g->out, ".Ldefault%d:\n", g->switch_label); - codegen_stmt(g, stmt->as.default_label->body); + codegen_switch_body(g, stmt->as.default_label->body, case_values, case_labels, n_cases); return true; } else if (stmt->kind == AstNodeKind_list) { bool default_label_emitted = false; |
