# Self Current Task — Now (main) ## Next: Phase 129-C(post-if / post_k) **Phase 129: Materialize join_k continuation(dev-only)** - 現状: Phase 129-B で join_k “if-as-last” を実体化(then/else は TailCall(join_k)) - 残り: post-if(`if { x=2 }; return x`)を post_k continuation で表現(join_k → post_k の tailcall) - 入口: `docs/development/current/main/phases/phase-129/README.md` ## 2025-12-18:Phase 127 完了 ✅ **Phase 127: unknown-read strict Fail-Fast(dev-only)** - unknown-read = reads - (writes ∪ inputs) を検出 - strict: `freeze_with_hint("phase127/unknown_read/", ...)` で即停止(hint必須) - dev-only non-strict: 理由ログ(tag + count + 先頭数件) - 入口: `docs/development/current/main/phases/phase-127/README.md` ## 2025-12-18:Phase 128 完了 ✅ **Phase 128: if-only partial assign keep/merge in Normalized (dev-only)** - StepStmtKind::Assign に value_ast 追加(Phase 128) - Normalized builder に Assign(int literal) 対応(env 更新) - Fixture: phase128_if_only_partial_assign_normalized_min.hako(簡易版) - Smoke: phase128_if_only_partial_assign_normalized_vm.sh(PASS) - Regression: Phase 121-126, 118 維持確認(全 PASS) - Unit tests: 1165/1165 PASS - 入口: `docs/development/current/main/phases/phase-128/README.md` - 実装: - `src/mir/control_tree/step_tree.rs` (value_ast 追加、14行追加) - `src/mir/control_tree/normalized_shadow/builder.rs` (Assign lowering、87行追加) - Note: 完全な join_k continuation は future work(Phase 128 は基本構造確立) ## 2025-12-18:Phase 126 完了 ✅ **Phase 126: available_inputs SSOT wiring (dev-only)** - AvailableInputsCollectorBox 実装(function params + CapturedEnv 収集) - try_lower_if_only() に available_inputs 配線(dev-only) - EnvLayout.inputs が実際に使用されるようになった - Fixture 強化: reads-only 変数の return 解決を確認 - Regression: Phase 121-125, 118 維持確認(全 PASS) - Unit tests: 28/28 PASS (including 5 new AvailableInputsCollectorBox tests) - Integration smoke: PASS (phase125_if_only_return_input_vm.sh, exit code 7) - 入口: `docs/development/current/main/phases/phase-126/README.md` - 実装: - `src/mir/control_tree/normalized_shadow/available_inputs_collector.rs` (143行、新規) - `src/mir/control_tree/normalized_shadow/builder.rs` (available_inputs 配線) - `src/mir/builder/calls/lowering.rs` (AvailableInputsCollectorBox::collect() 呼び出し) ## 2025-12-18:Phase 125 P2-P5 完了 ✅ **Phase 125 P2-P5: Reads-Only Env Inputs (dev-only, structure)** - EnvLayout 導入(writes + inputs の 2 レーン化) - from_contract: reads ∩ available_inputs で inputs を決定(決定的順序) - Return(Variable) 解決拡張: writes or inputs から解決 - Fail-Fast with hint: env に無い変数は構造化エラー - Unit tests: 18/18 PASS (including new test_return_variable_from_inputs_stub) - Integration smoke: PASS (phase125_if_only_return_input_vm.sh, exit code 7) - Regression: Phase 121-124, 118 維持確認(全 PASS) - 入口: `docs/development/current/main/phases/phase-125/README.md` - 実装: - `src/mir/control_tree/normalized_shadow/builder.rs` (EnvLayout, 186行追加) - Note: P3 (available_inputs wiring) 未実装、inputs は空(structure-only) ## 2025-12-18:Phase 124 完了 ✅ **Phase 124: Normalized reads facts + Return(Variable from env)(dev-only)** - StepTreeFacts に reads 追加(Variable 参照を AST から抽出) - StepTreeContract signature に reads 反映(決定性維持) - env マッピング(変数名 → ValueId)を writes から生成 - Return(Variable) サポート: env にある変数のみ(writes 由来) - env に無い Variable は Fail-Fast エラー(phase124 error → Ok(None) fallback) - Box-first modularization: extract_variables_from_ast() で SSOT 化 - Unit tests: 1159 tests PASS (including test_return_variable_from_env) - Integration smoke: PASS (`phase124_if_only_return_var_vm.sh`, exit code 7 許容) - 回帰: Phase 121/123/118 維持確認 - 入口: `docs/development/current/main/phases/phase-124/README.md` - 実装: - `src/mir/control_tree/step_tree_facts.rs` (reads 追加、76行) - `src/mir/control_tree/step_tree_contract_box.rs` (reads 反映、101行) - `src/mir/control_tree/step_tree.rs` (extract_variables_from_ast 追加、612行) - `src/mir/control_tree/normalized_shadow/builder.rs` (env マッピング追加、837行) ## 2025-12-18:Phase 123 完了 ✅ **Phase 123: if-only Normalized semantics(dev-only)** - Return(Integer literal) → `Const + Ret(Some(vid))` 生成 - Return(Variable) → `Ok(None)` (graceful degradation, Phase 124 で対応) - If(minimal compare) → Variable vs Integer literal のみ対応 - Graceful degradation: Phase 123 制限は `Ok(None)` で legacy に fallback - Structured error codes: `[phase123/...]` prefix で明示的エラー - Box-first modularization: parse/verify/lower 責務分離 - Unit tests: 8 tests PASS (including graceful degradation test) - Integration smoke: PASS (`phase123_if_only_normalized_semantics_vm.sh`) - 入口: `docs/development/current/main/phases/phase-123/README.md` ## 2025-12-18:Phase 121 完了 ✅ **Phase 121: StepTree→Normalized Shadow Lowering (if-only, dev-only)** - 箱化モジュール化: normalized_shadow/{contracts,builder,parity}.rs (508行、新規) - Shadow lowering: StepTree → JoinModule (Normalized方言、if-only限定) - Capability guard: Loop/Break/Continue を明示的拒否(SSOT) - Parity 検証: exit contracts + writes 比較(dev ログ / strict fail-fast) - Dev-only wiring: `joinir_dev_enabled()` のときのみ shadow 生成 - Strict fail-fast: `freeze_with_hint` で mismatch を即座に検出(hint必須) - Smoke tests: VM 3/3 PASS、LLVM スタブ(ハーネス設定必要) - 回帰: Phase 120 維持確認、全テスト PASS - 入口: `docs/development/current/main/phases/phase-121/README.md` - 設計: `docs/development/current/main/design/control-tree.md` (Phase 121章) ## 2025-12-18:Phase 120 完了 ✅ **Phase 120: StepTree "Facts→Decision→Emit" 箱化モジュール化** - 箱化モジュール化: StepTreeFacts / StepTreeContractBox の責務分離 - StepTreeBuilderBox: 構造 + facts 抽出まで(意思決定・整形・署名生成はしない) - StepTreeContractBox: facts → contract の整形のみ(idempotent, deterministic) - BTreeSet で順序決定性保証(facts は順序に依存しない) - signature_basis_string() の決定性維持(既定挙動不変) - 回帰: Phase 103/118 維持確認、全 1142 テスト PASS - 入口: `docs/development/current/main/design/control-tree.md` - 実装: - `src/mir/control_tree/step_tree_facts.rs` (63行、新規) - `src/mir/control_tree/step_tree_contract_box.rs` (168行、新規) - `src/mir/control_tree/step_tree.rs` (262→411行、リファクタリング) ## 2025-12-18:Phase 119 完了 ✅ **Phase 119: StepTree cond SSOT(AST handle)** - StepNode::If / StepNode::Loop に cond_ast (AstNodeHandle) を追加 - SSOT: cond は AST 参照を保持、cond_sig は派生(署名/ログ/差分検知) - 不変条件: cond_ast は signature_basis_string() に混ぜない(決定性維持) - 実装: Box clone(dev-only なので許容) - 回帰: Phase 103/104/118 維持確認 - 入口: `docs/development/current/main/design/control-tree.md` ## 2025-12-18:Phase 118 完了 ✅ **Phase 118: loop + if-only merge parity** - loop + if-only で条件付き変数更新 merge を VM/LLVM で固定 - Fixture: phase118_loop_nested_if_merge_min.hako (expected: 2) - Pattern3 (if-sum) 活用 - Smoke: VM + LLVM EXE parity 検証済み - Follow-up: Pattern3 carrier PHI contract(expected: 12) - Fixture: phase118_pattern3_if_sum_min.hako - Smoke: phase118_pattern3_if_sum_{vm,llvm_exe}.sh - 回帰: Phase 117 維持確認 - 入口: `docs/development/current/main/phases/phase-118/README.md` ## 2025-12-18:Phase 117 完了 ✅ **Phase 117: if-only nested-if + call merge parity** - ネストしたif-only(内側if + 外側else)で call 結果 merge を VM/LLVM で固定 - Fixture: phase117_if_only_nested_if_call_merge_min.hako (expected: 2, 3, 4) - Smoke: VM + LLVM EXE parity 検証済み - 回帰: Phase 116 維持確認 - 入口: `docs/development/current/main/phases/phase-117/README.md` ## 2025-12-18:Phase 116 完了 ✅ **Phase 116: if-only keep+call merge parity** - if-only で片側が元値保持、片側が call 結果のパターンを VM/LLVM で固定 - Fixture: phase116_if_only_keep_plus_call_min.hako (expected: 10, 2) - Smoke: VM + LLVM EXE parity 検証済み - 回帰: Phase 115 維持確認 - 入口: `docs/development/current/main/phases/phase-116/README.md` ## 2025-12-18:Phase 115 完了 ✅ **Phase 115: if-only call result merge parity** - if-only で関数呼び出し結果を merge するパターンを VM/LLVM で固定 - Fixture: phase115_if_only_call_merge_min.hako (expected: 2, 3) - Smoke: VM + LLVM EXE parity 検証済み - 回帰: Phase 103/113/114 維持確認 - 入口: `docs/development/current/main/phases/phase-115/README.md` ## 2025-12-18:Phase 114 完了 ✅ **Phase 114: if-only return+post parity** - if-only で early return + post-if statements パターンを VM/LLVM で固定 - Fixture: phase114_if_only_return_then_post_min.hako (expected: 7, 2) - Smoke: VM + LLVM EXE parity 検証済み - 回帰: Phase 103/113 維持確認 - 入口: `docs/development/current/main/phases/phase-114/README.md` ## 2025-12-18:Phase 113 完了 ✅ **Phase 113: if-only partial assign parity** - if-only(else なし)の片側代入で「保持 merge」パターンを VM/LLVM で固定 - Fixture: phase113_if_only_partial_assign_min.hako - Smoke: VM + LLVM EXE parity 検証済み ## 2025-12-18:Phase 112 完了 ✅ **Phase 112: StepTree Capability Guard (strict-only)** - StepTree の required_caps を strict mode でチェック - Allowlist: If, NestedIf, Loop, Return, Break, Continue - Deny (strict): NestedLoop, TryCatch, Throw, Lambda, While, ForRange, Match, Arrow - Error format: `[joinir/control_tree/cap_missing/] Hint: ` - Default behavior unchanged (strict=false always Ok) - 入口: `docs/development/current/main/design/control-tree.md` - 実装: - `src/mir/builder/control_flow/joinir/control_tree_capability_guard.rs` - `src/mir/builder/calls/lowering.rs` (wired into lower_function_body) ## 2025-12-18:Phase 111 完了 ✅ **Phase 111: StepTreeContract + StepTreeSignature(dev-only)** - StepTreeContract を追加(`exits` / `writes` / `required_caps` / `cond_sig`) - StepTreeSignature を追加(`signature_basis_string()` を安定 hash、Span は含めない) - dev-only parity を break/continue に加えて return まで拡張 - 入口: `docs/development/current/main/design/control-tree.md` - 実装: `src/mir/control_tree/step_tree.rs` ## 2025-12-18:Phase 110 完了 ✅ **Phase 110: ControlTree / StepTree(構造SSOT・dev-only観測)** - StepTree の語彙(Block/If/Loop/Stmt)と Feature を pure AST で実装(ValueId/PHI/CFG を混ぜない) - joinir routing 側で extractor との “分類矛盾” を dev-only で検出(strict のみ Fail-Fast) - 関数本体の StepTree を dev-only でダンプ(既定挙動不変) - 入口: `docs/development/current/main/design/control-tree.md` - 実装: - `src/mir/control_tree/step_tree.rs` - `src/mir/builder/calls/lowering.rs` - `src/mir/builder/control_flow/joinir/routing.rs` ## 2025-12-17:Phase 109 完了 ✅ **Phase 109: error_tags hints SSOT** - policy/validator エラーを "tag + message + hint" 形式に統一 - freeze_with_hint() API 追加(hint 必須、空なら panic) - Phase 107/104/100 の代表3箱を hint 対応に移行 - 入口: `docs/development/current/main/phases/phase-109/README.md` ## 2025-12-17:Phase 104 完了 ✅ **Phase 104: loop(true) + break-only digits(read_digits 系)** - read_digits_from 形の `loop(true)` を Pattern2 で受理(loop var 抽出 + break cond 正規化) - fixture: `apps/tests/phase104_read_digits_loop_true_min.hako`(expected: `2`, `1`) - smoke: `tools/smokes/v2/profiles/integration/apps/phase104_read_digits_vm.sh` / `tools/smokes/v2/profiles/integration/apps/phase104_read_digits_llvm_exe.sh` - P2: json_cur 由来の回帰面を追加(fixture+VM/LLVM EXE smoke) ## 2025-12-17:Phase 107 完了 ✅ **Phase 107: json_cur find_balanced_* depth scan(VM + LLVM EXE parity)** - depth scan + nested if + return-in-loop を Pattern2 policy で受理(hardcode なし) - fixture: - `apps/tests/phase107_find_balanced_array_end_min.hako`(expected: `1`, `3`) - `apps/tests/phase107_find_balanced_object_end_min.hako`(expected: `1`, `3`) - smoke(integration): - VM: `tools/smokes/v2/profiles/integration/apps/phase107_find_balanced_array_end_vm.sh` / `tools/smokes/v2/profiles/integration/apps/phase107_find_balanced_object_end_vm.sh` - LLVM EXE: `tools/smokes/v2/profiles/integration/apps/phase107_find_balanced_array_end_llvm_exe.sh` / `tools/smokes/v2/profiles/integration/apps/phase107_find_balanced_object_end_llvm_exe.sh` - 入口: `docs/development/current/main/phases/phase-107/README.md` ## 2025-12-17:Phase 108 完了 ✅ **Phase 108: Pattern2 policy router SSOT(薄い入口の固定)** - post-loop early return を一般 plan(`cond`/`ret_expr`)として独立し、Pattern2Inputs の依存を解消 - ApplyPolicyStepBox から “直叩き” を撤去し、policy router 1本に集約(入口SSOT) - 入口: `docs/development/current/main/phases/phase-108/README.md` ## 2025-12-17:Phase 103 P0 完了 ✅ **Phase 103: if-only regression baseline** - if-only(loop無し)の nested if + merge を fixture 化し、VM/LLVM EXE parity を integration smoke で固定 ## 2025-12-17:Phase 100 P3 完了 ✅ **Phase 100 P3: String Accumulator Captures** - String accumulator(`out = out + ch`)を最小形で固定し、VM/LLVM EXE parity を smoke で検証 - LLVM EXE 側の stringish 伝播(PHI/copy/binop)を修正し、concat の意味論を安定化 ## 2025-12-17:Phase 100 P2 完了 ✅ **Phase 100 P2: Mutable Accumulator Captures** - Mutable accumulator pattern (`out = out + ch`) を Pattern2 carrier で対応 - ScopeManager 委譲により read-only check を回避 - Numeric output validation (count=3) で fixture 固定 - VM/LLVM EXE parity 完了(smoke 追加) ## 2025-12-17:Phase 100 P1 完了 ✅ **Phase 100 P1: Pinned Local Captures** - CapturedEnv に CapturedKind (Explicit/Pinned) 拡張 - PinnedLocalAnalyzer で loop-outer read-only locals を識別 - Pinned receiver (例: s.substring()) が loop 内で使用可能に - Fixture/smoke で動作確認済み ## 2025‑12‑17:Phase 99 完了 ✅ **Phase 99: Trim/escape 実コード寄り強化(VM+LLVM EXE)** - next_non_ws を3ケース固定(`2`, `-1`, `3`)— 改行/CR/Tab混在パターン追加 - escape 末尾バックスラッシュを best-effort として固定(`hello\` そのまま出力) - VM+LLVM EXE parity 完全対応、integration smoke で検証済み 関連(設計/実装の入口): - Phase 100: `docs/development/current/main/phases/phase-100/README.md` ## 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` ## 2025‑12‑16:Phase 92(短報) - Phase 92(ConditionalStep / P5b escape の lowering 基盤)は完了。 - 条件付き更新(`ConditionalStep`)のJoinIR表現 + Pattern2 側の委譲(emitter 箱化) - 条件式での body-local 参照(`ConditionEnv → LoopBodyLocalEnv`)+ 最小E2E smoke 固定 - Phase 記録(SSOT入口): `docs/development/current/main/phases/phase-92/README.md` - 残: P5b の “完全E2E” は body-local promotion 拡張後(スコープ外で保留) ## 2025‑12‑16:Phase 93(短報) - Trim の `is_ch_match` など「ConditionOnly(PHIで運ばない派生値)」を Derived Slot として毎イテレーション再計算できるようにした。 - SSOT: `ConditionOnlyRecipe`(運搬禁止)+ `ConditionOnlyEmitter` - schedule: `body-init → derived → break` を評価順SSOTとして強制 - Phase 記録(入口): `docs/development/current/main/phases/phase-93/README.md` ## 2025‑12‑16:Phase 94(短報) - P5b escape(`ch` 再代入 + `i` の +1/+2)を “derived(Select)” として扱い、VM E2E を固定。 - 新箱: `BodyLocalDerivedEmitter` + 明示ポリシー(strict で理由付き Fail-Fast) - integration smoke: `tools/smokes/v2/profiles/integration/apps/phase94_p5b_escape_e2e.sh` - Phase 記録(入口): `docs/development/current/main/phases/phase-94/README.md` ## 2025‑12‑16:Phase 95(短報) - MiniJsonLoader の escape ループを Phase 94 基盤で固定(派生 body-local + 条件付き skip)。 - フィクスチャ: `apps/tests/phase95_json_loader_escape_min.hako` - smoke: `tools/smokes/v2/profiles/integration/apps/phase95_json_loader_escape_vm.sh` - Phase 記録(入口): `docs/development/current/main/phases/phase-95/README.md` ## 2025‑12‑16:Phase 96(短報) - Trim系 policy 化を開始し、MiniJsonLoader の next_non_ws ループを fixtures/smoke に追加。 - フィクスチャ: `apps/tests/phase96_json_loader_next_non_ws_min.hako` - smoke: `tools/smokes/v2/profiles/integration/apps/phase96_json_loader_next_non_ws_vm.sh` - Phase 記録(入口): `docs/development/current/main/phases/phase-96/README.md` ## 2025‑12‑16:Phase 97(短報) - Phase 95/96 の MiniJsonLoader fixture を LLVM EXE ラインでも固定し、JoinIR/Trim の退行検出を強化。 - smoke: `tools/smokes/v2/profiles/integration/apps/phase97_next_non_ws_llvm_exe.sh`(next_non_ws) - smoke: `tools/smokes/v2/profiles/integration/apps/phase97_json_loader_escape_llvm_exe.sh`(escape) - Phase 記録(入口): `docs/development/current/main/phases/phase-97/README.md` ## 2025‑12‑17:Phase 98(短報) - plugin loader に strict fail-fast を導入し(HAKO_JOINIR_STRICT=1)、FileBox/MapBox の LLVM EXE parity を持続可能に。 - smoke: `tools/smokes/v2/profiles/integration/apps/phase97_next_non_ws_llvm_exe.sh` - smoke: `tools/smokes/v2/profiles/integration/apps/phase97_json_loader_escape_llvm_exe.sh` - Phase 記録(入口): `docs/development/current/main/phases/phase-98/README.md` ## 2025‑12‑17:Phase 102(短報) - real-app(MiniJsonLoader.read_quoted_from)の loop を最小抽出し、VM + LLVM EXE で regression を固定(期待: length=4)。 - フィクスチャ: `apps/tests/phase102_realapp_read_quoted_min.hako` - smoke: `tools/smokes/v2/profiles/integration/apps/phase102_realapp_read_quoted_vm.sh` - smoke: `tools/smokes/v2/profiles/integration/apps/phase102_realapp_read_quoted_llvm_exe.sh` - Phase 記録(入口): `docs/development/current/main/phases/phase-102/README.md` ## 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` / `ExitBindingBuilder` - `JoinInlineBoundary` + `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.md` - `docs/development/current/main/phase78-bindingid-promoted-carriers.md` - `docs/development/current/main/phase80-bindingid-p3p4-plan.md` - `docs/development/current/main/phase81-pattern2-exitline-contract.md` - `docs/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.md` - `docs/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 で先に整える方針。 直近タスク(当時) 1) continue/break の lowering(Builder 修正のみで表現) - ループ文脈スタック {head, exit} を導入。 - continue に遭遇 → head(または latch)へ br を emit し終端。 - break に遭遇 → exit へ br を emit し終端。 - post‑terminated 後に emit しない制御を徹底。 2) ループ CFG の厳密化 - 単一 exit ブロックの徹底。 - Phi はヘッダでキャリー変数を合流(SSA/支配関係が崩れない形)。 3) 検証とスモーク - 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`