stage3: unify to cleanup; MIR return-defer; docs+smokes updated; LLVM(harness): finalize_phis ownership, ret.py simplified, uses-predeclare; cleanup return override green; method-postfix cleanup return WIP (PHI head)

This commit is contained in:
Selfhosting Dev
2025-09-19 02:07:38 +09:00
parent 951a050592
commit 5e818eeb7e
205 changed files with 9671 additions and 1849 deletions

View File

@ -0,0 +1,21 @@
# BlockPostfix Catch Language Design (Draft)
Goal
- Make exception boundaries explicit by attaching `catch`/`cleanup` to standalone blocks.
Design
- Syntax: `{ body } catch (e) { handler } [cleanup { … }]` and `{ body } cleanup { … }`.
- Policy: single catch (branch inside the catch); scope limited to the same block; no implicit propagation.
- Static check (MVP): direct `throw` in a standalone block requires an immediate postfix `catch`.
Implementation Notes
- Parser (gated): normalize postfix to `ASTNode::TryCatch`.
- Bridge(Resultmode): ThrowCtx routes nested `throw` to the single catch; merge with PHIoff.
- Friendly errors: disallow toplevel leading `catch`/`cleanup`, and attaching to structural if/loop blocks.
References
- Parser: `src/parser/statements.rs`
- Smokes: `src/tests/parser_block_postfix_{catch,errors}.rs`
Open Questions
- Multiple catch with type hierarchy; effects typing for static checks; formatter support.