feat(loop-phi): Add body-local variable PHI generation for Rust AST loops
Phase 25.1c/k: Fix ValueId undefined errors in loops with body-local variables **Problem:** - FuncScannerBox.scan_all_boxes/1 and BreakFinderBox._find_loops/2 had ValueId undefined errors for variables declared inside loop bodies - LoopFormBuilder only generated PHIs for preheader variables, missing body-locals - Example: `local ch = s.substring(i, i+1)` inside loop → undefined on next iteration **Solution:** 1. **Rust AST path** (src/mir/loop_builder.rs): - Detect body-local variables by comparing body_end_vars vs current_vars - Generate empty PHI nodes at loop header for body-local variables - Seal PHIs with latch + continue snapshot inputs after seal_phis() - Added HAKO_LOOP_PHI_TRACE=1 logging for debugging 2. **JSON v0 path** (already fixed in previous session): - src/runner/json_v0_bridge/lowering/loop_.rs handles body-locals - Uses same strategy but for JSON v0 bridge lowering **Results:** - ✅ FuncScannerBox.scan_all_boxes: 41 body-local PHIs generated - ✅ Main.main (demo harness): 23 body-local PHIs generated - ⚠️ Still some ValueId undefined errors remaining (exit PHI issue) **Files changed:** - src/mir/loop_builder.rs: body-local PHI generation logic - lang/src/compiler/entry/func_scanner.hako: debug logging - /tmp/stageb_funcscan_demo.hako: test harness 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
@ -48,7 +48,7 @@ Status: planning(構造整理フェーズ・挙動は変えない)
|
||||
が 1 関数に詰め込まれており、MIR 上でも巨大な `Main.main` になっている。
|
||||
- 25.1c ではこれを「箱理論」に沿って分割する方針を立てており、Phase 25.1c 冒頭でまず Stage‑B 側を 4 箱構造にリファクタした:
|
||||
- `Main`(エントリ薄箱): `main(args){ return StageBDriverBox.main(args) }` のみを担当。
|
||||
- `StageBDriverBox`(オーケストレーション): `StageBArgsBox.resolve_src` → `StageBBodyExtractorBox.build_body_src` → `ParserBox.parse_program2` → defs 挿入 → `print(ast_json)` だけを見る。
|
||||
- `StageBDriverBox`(オーケストレーション): `StageBArgsBox.resolve_src` → `StageBBodyExtractorBox.build_body_src` → `ParserBox.parse_block2` → defs 挿入 → `print(ast_json)` だけを見る。
|
||||
- `StageBArgsBox`(CLI 引数と bundle/require の扱いだけを担当): もともとの「args/src/src_file/HAKO_SOURCE_FILE_CONTENT/return 0」ロジックを完全移動。
|
||||
- `StageBBodyExtractorBox`(`body_src` 抽出ロジック+bundle/using/trim を担当): もともとの `body_src` 抽出〜コメント削除〜BundleResolver/Stage1UsingResolverBox〜前後 trim までを丸ごとカプセル化。
|
||||
- いずれもロジックはそのまま移動であり、コメント・using・ログを含めて挙動は完全に不変(同じ Program(JSON v0)、同じログ、同じ `VM error: Invalid value`)であることを selfhost CLI サンプルで確認済み。エラーの発生箇所は `Main.main` から `StageBArgsBox.resolve_src/1` に関数名だけ変わっており、SSA/Loop 側の根本修正はこの後のタスク(LoopBuilder / LocalSSA 整理)で扱う。
|
||||
@ -92,11 +92,11 @@ Status: planning(構造整理フェーズ・挙動は変えない)
|
||||
- 代表 canary:
|
||||
- `tools/smokes/v2/profiles/quick/core/phase251/stageb_fib_program_defs_canary_vm.sh`
|
||||
- `tools/smokes/v2/profiles/quick/core/phase251/selfhost_cli_run_basic_vm.sh`
|
||||
- まずは `compiler_stageb.hako` の流れを箱ごとに分解してログする:
|
||||
- `StageBArgsBox.resolve_src`
|
||||
- `StageBBodyExtractorBox.build_body_src`
|
||||
- `ParserBox.parse_program2`
|
||||
- `FuncScannerBox.scan_all_boxes`
|
||||
- まずは `compiler_stageb.hako` の流れを箱ごとに分解してログする:
|
||||
- `StageBArgsBox.resolve_src`
|
||||
- `StageBBodyExtractorBox.build_body_src`
|
||||
- `ParserBox.parse_program2` / `ParserBox.parse_block2`
|
||||
- `StageBFuncScannerBox.scan_all_boxes`(Phase 25.1c 時点では Stage‑B ローカル実装)
|
||||
- 各箱の入口/出口に `[stageb/trace:<box>.<method>:enter|leave]` のような軽いタグを置き、どの箱が rc=1 の直前で止まっているかを特定する(挙動は変えない)。
|
||||
|
||||
- 2) Rust Region レイヤを「正解ビュー」として .hako 側を寄せる
|
||||
|
||||
Reference in New Issue
Block a user