Phase 92 P2-2完了:ConditionalStepのcondition(ch == '\\'など)でbody-local変数をサポート ## 主要変更 ### 1. condition_lowerer.rs拡張 - `lower_condition_to_joinir`に`body_local_env`パラメータ追加 - 変数解決優先度:ConditionEnv → LoopBodyLocalEnv - すべての再帰ヘルパー(comparison, logical_and, logical_or, not, value_expression)対応 ### 2. conditional_step_emitter.rs修正 - `emit_conditional_step_update`に`body_local_env`パラメータ追加 - condition loweringにbody-local環境を渡す ### 3. loop_with_break_minimal.rs修正 - break condition loweringをbody-local init の**後**に移動(line 411) - header_break_lowering::lower_break_conditionにbody_local_env渡す - emit_conditional_step_updateにbody_local_env渡す(line 620) ### 4. header_break_lowering.rs修正 - `lower_break_condition`に`body_local_env`パラメータ追加 - scope_managerにbody-local環境を渡す ### 5. 全呼び出し箇所修正 - expr_lowerer.rs (2箇所) - method_call_lowerer.rs (2箇所) - loop_with_if_phi_if_sum.rs (3箇所) - loop_with_continue_minimal.rs (1箇所) - carrier_update_emitter.rs (1箇所・legacy) ## アーキテクチャ改善 ### Break Condition Lowering順序修正 旧: Header → **Break Cond** → Body-local Init 新: Header → **Body-local Init** → Break Cond 理由:break conditionが`ch == '\"'`のようにbody-local変数を参照する場合、body-local initが先に必要 ### 変数解決優先度(Phase 92 P2-2) 1. ConditionEnv(ループパラメータ、captured変数) 2. LoopBodyLocalEnv(body-local変数like `ch`) ## テスト ### ビルド ✅ cargo build --release成功(30 warnings、0 errors) ### E2E ⚠️ body-local promotion問題でブロック(Phase 92範囲外) - Pattern2はbody-local変数をcarrier promotionする必要あり - 既存パターン(A-3 Trim, A-4 DigitPos)に`ch = get_char(i)`が該当しない - **Phase 92 P2-2目標(condition loweringでbody-local変数サポート)は達成** ## 次タスク(Phase 92 P3以降) - body-local variable promotion拡張(Pattern2で`ch`のような変数を扱う) - P5b E2Eテスト完全動作確認 ## Phase 92 P2-2完了 ✅ Body-local変数のcondition lowering対応完了 ✅ ConditionalStepでbody-local変数参照可能 ✅ Break condition lowering順序修正
9.2 KiB
9.2 KiB
Self Current Task — Now (main)
2025‑12‑15:Phase 132 完了 ✅
Phase 132: LLVM Exit PHI=0 根治修正 完了!
- ループ exit PHI が 0 を返す問題を根治解決
- 原因(2層): (1) JoinIR/Boundary が exit 値を境界に渡していない、(2) LLVM Python が PHI を落とす/上書きする
- 修正: Pattern 1 で exit 値を明示的に渡す +
predeclared_ret_phis使用 +builder.vmapの PHI 保護 - 結果:
/tmp/p1_return_i.hakoが 3 を返す(VM 一致) - 詳細:
investigations/phase132-llvm-exit-phi-wrong-result.md
追加(Phase 132-P2): Case C の Exit PHI ValueId 衝突を修正
- 原因:
exit_phi_builder.rsが module-level allocator を使い、同一関数内で ValueId が衝突し得た - 修正:
func.next_value_id()(function-level)へ統一(bd07b7f4) - 結果:
apps/tests/llvm_stage3_loop_only.hakoが LLVM EXE でもResult: 3(VM 一致) - 詳細:
investigations/phase132-case-c-llvm-exe.md
追加(Phase 132-P3): Exit PHI collision の早期検出(debug-only)
verify_exit_phi_no_collision()をcontract_checks.rsに追加し、ValueId 衝突を JoinIR merge の段階で Fail-Fast する
2025‑12‑15:Phase 133–136(短報)
- Phase 133: promoted carrier(Trim)の
join_id解決を SSOT に寄せて修正(smoke は compile-only)。 - Phase 134: plugin loader best-effort loading を導入(決定的順序 + failure 集約 + 継続)。
- Phase 135: ConditionLoweringBox が allocator SSOT を無視して ValueId 衝突を起こす問題を根治。
- 詳細:
docs/development/current/main/phases/phase-135/README.md
- 詳細:
- Phase 136: MirBuilder の Context 分割を完了し、状態の SSOT を Context に一本化。
- 詳細:
docs/development/current/main/phases/phase-136/README.md
- 詳細:
2025‑12‑16:Phase 137‑141(短報)
- Loop Canonicalizer(前処理 SSOT)は Phase 141 まで完了(既定挙動は不変、dev-only 観測/strict parity あり)。
- 設計 SSOT:
docs/development/current/main/design/loop-canonicalizer.md - 実装:
src/mir/loop_canonicalizer/mod.rs(+ 観測:src/mir/builder/control_flow/joinir/routing.rs) - Phase 記録:
docs/development/current/main/phases/phase-137/README.md
- 設計 SSOT:
2025‑12‑16:Phase 92(短報)
- P5b escape の lowering を進行中。P1 で
ConditionalStepemitter を箱化して、Pattern2 本体の肥大化を防いだ。- Phase 記録:
docs/development/current/main/phases/phase-92/README.md
- Phase 記録:
2025‑12‑14:現状サマリ
(補足)docs が増えて迷子になったときの「置き場所ルール(SSOT)」:
docs/development/current/main/DOCS_LAYOUT.md
JoinIR / Loop / If ライン
- LoopBuilder は Phase 186‑187 で完全削除済み。JoinIR が唯一の loop lowering 経路。
- LoopPattern 系は Pattern1–4 まで実装・本線化済み:
- Pattern1: Simple While
- Pattern2: Loop with Break
- Pattern3: Loop with If‑Else PHI(break/continue なし)
- Pattern4: Loop with Continue(multi‑carrier 対応)
- Exit/Carrier/Boundary ラインは次の箱で SSOT 化:
CarrierInfo/ExitMeta/ExitBindingBuilderJoinInlineBoundary+LoopExitBinding
- If lowering は IfSelectLowerer/IfMergeLowerer を中心に整理済み。Select/PHI の扱いも Phase 189 系で橋渡し済み。
- 残課題(JoinIR ライン):
- JoinIR→MIR merge の一般化(複雑な Select/PHI パターンの統合)
- JsonParserBox など実アプリ側での長期運用テスト
- Phase 86–90(Loop frontends)まとめ(1枚):
docs/development/current/main/phase86-90-loop-frontends-summary.md
Phase 86–90: Loop frontends(要約)
- Phase 86–90 は “dev-only fixtures + shape guard + fail-fast” で段階的に固定済み。
- 具体の fixture / shape / 未検証は
docs/development/current/main/phase86-90-loop-frontends-summary.mdを SSOT とする。
Scope / BindingId(dev-only の段階移行ライン)
- MIR builder 側で lexical scope / shadowing を実在化し、言語仕様の “local はブロック境界で分離” を SSOT に揃えた。
- JoinIR lowering 側は name-based から BindingId-based へ段階移行中:
ScopeManager.lookup_with_binding()/ConditionEnv.binding_id_mapを導入し、shadowing を壊さずに解決できる足場を作った。- promoted carriers(DigitPos/Trim)については
BindingId(original) → BindingId(promoted) → ValueId(join)の鎖を dev-only で整備中。 - Phase 86 で
carrier_init_builder/error_tagsを SSOT 化し、段階移行ラインの基盤(ValueId 生成とエラー語彙)が確立した。 - これにより、BindingId dual-path の拡張・統合時に「生成」と「表示」の責務が混ざらない構造が固定された。
- Phase 81 で Pattern2(DigitPos/Trim)の ExitLine 契約(ConditionOnly を exit PHI から除外、LoopState のみを reconnect)を E2E で固定した。
- 参照:
docs/development/current/main/phase73-scope-manager-design.mddocs/development/current/main/phase78-bindingid-promoted-carriers.mddocs/development/current/main/phase80-bindingid-p3p4-plan.mddocs/development/current/main/phase81-pattern2-exitline-contract.mddocs/development/current/main/phase78-85-boxification-feedback.md
JsonParser / Selfhost depth‑2 ライン
selfhost_build.sh --jsonで Program JSON v0 emit は安定。
.hako側から env 経由で JSON を読む最小ループ(program_read_min.hako)は動作確認済み。- JsonParserBox / BundleResolver のループ 21 本のうち:
- 18 本は Pattern1–4 で JoinIR 対応済み(Phase 162–165)。
_trimを含む一部の複合ループは、ValueId 境界や Box 登録など残課題あり。
- BoolExprLowerer / condition_to_joinir で OR/AND/NOT 付き条件式の lowering は実装完了(Phase 168–169)。
- 残課題(JsonParser/selfhost depth‑2):
- JoinIR→MIR ValueId boundary の完全一般化(条件用 ValueId を含める)
- JsonParserBox の using / Box 登録(Rust VM 側での認識)
- Program JSON v0 を JsonParserBox 経由でフル解析する line の仕上げ
Ring0 / Runtime / CoreServices ライン
- Ring0Context + Ring0Registry で OS API 抽象化レイヤ完成:
- MemApi / IoApi / TimeApi / LogApi / FsApi / ThreadApi
- RuntimeProfile(Default / NoFs) で条件付き必須を制御。
- CoreServices(ring1‑core)として次を実装済み:
- StringService / IntegerService / BoolService
- ArrayService / MapService / ConsoleService
- PluginHost 統合 + UnifiedBoxRegistry からの自動初期化
- FileBox / FileHandleBox ライン:
- Ring0FsFileIo 経由で read / write / append / metadata 完全対応
- Default プロファイルでは必須、NoFs プロファイルでは disabled。
- Logging ライン:
- ConsoleService(user‑facing)
- Ring0.log(internal/dev)
- println!(test 専用)
の 3 層が
logging_policy.mdで整理済み。JoinIR/Loop trace も同ドキュメントに集約。
- VM backend の Box 解決(UnifiedBoxRegistry / BoxFactoryRegistry)の経路図:
docs/development/current/main/phase131-2-box-resolution-map.md
- LLVM(Python llvmlite)lowering の棚卸し(Phase 131-3..10):
docs/development/current/main/phase131-3-llvm-lowering-inventory.md- 状態: Case B(Pattern1/loop_min_while)は EMIT/LINK/RUN まで復旧済み。Phase 132 で
return iの VM/LLVM parity を固定。 - Case C は別途 “Case C docs” を SSOT にして追跡する(状況は更新されるので、この箇所では断定しない)
- Case C の調査と実装計画:
docs/development/current/main/phase131-11-case-c-summary.mddocs/development/current/main/case-c-infinite-loop-analysis.md
2025‑09‑08:旧スナップショット(参考)
- LLVM 側 P0 完了(BitOps/Array/Echo/Map 緑)。VInvoke(by‑name/by‑id vector) は戻り値マッピングの暫定課題を確認中(Decisions 参照)。
- selfhosting-dev の作業を main に順次取り込み。VM/MIR 基盤は main で先に整える方針。
直近タスク(当時)
- continue/break の lowering(Builder 修正のみで表現)
- ループ文脈スタック {head, exit} を導入。
- continue に遭遇 → head(または latch)へ br を emit し終端。
- break に遭遇 → exit へ br を emit し終端。
- post‑terminated 後に emit しない制御を徹底。
- ループ CFG の厳密化
- 単一 exit ブロックの徹底。
- Phi はヘッダでキャリー変数を合流(SSA/支配関係が崩れない形)。
- 検証とスモーク
- Verifier 緑(dominance/SSA)。
- VM のループ代表(単純/ネスト/早期継続・脱出)。
- LLVM/Cranelift EXE に綺麗に降りる(br/phi ベースで問題なし)。
代表コマンド(例)
- ビルド:
cargo build --release - LLVM smoke:
LLVM_SYS_180_PREFIX=$(llvm-config-18 --prefix) NYASH_LLVM_BITOPS_SMOKE=1 ./tools/llvm_smoke.sh release - VInvoke 調査:
NYASH_LLVM_VINVOKE_TRACE=1 NYASH_LLVM_VINVOKE_SMOKE=1 ./tools/llvm_smoke.sh release