Files
hakorune/CURRENT_TASK.md

364 lines
31 KiB
Markdown
Raw Normal View History

# Current Task — JoinIR / PHI 削減スナップショット2025-11-29 時点)
> このファイルは「今どこまで終わっていて、次に何をやるか」を 1000 行以内でざっくり把握するためのスナップショットだよ。
> 過去の詳細ログは `docs/private/roadmap2/CURRENT_TASK_2025-11-29_full.md` や各 Phase の README/TASKS を見てね。
---
## 0. 現在地ざっくり
- **✅ JoinIR ラインは Phase 68 で一旦 Chapter Close**
- Phase 27-67 で JoinIR の「第1章構造 + PHI + 型ヒント SSOT」が完了。
- 4つの柱Structure / Scope / JoinIR / Type Hintsが確立。
- Trio 削除ラインPhase 70 完了を経て、wasm/Web デモラインと最適化ラインに分岐。
- 詳細: [phase-30-final-joinir-world/README.md](docs/private/roadmap2/phases/phase-30-final-joinir-world/README.md)
- **最終ゴール**
- 制御構造と PHI の意味論は **JoinIRLoopScopeShape/IfPhiContext 等の薄い箱)** に一本化する。
- 実行の SSOT は VM / LLVM ラインとし、JoinIR→MIR→VM/LLVM は「構造 SSOT → 実行 SSOT」への変換として扱う。
- 既存の PHI 箱if_phi.rs / PhiBuilderBox / conservative.rs / Trio 等は、JoinIR 側のカバレッジが十分になったところから順に削っていく。
- Stage-3 parser デフォルトON化Phase 30.1 完了): `config::env::parser_stage3_enabled()` で NYASH_FEATURES=stage3 をSSOT化し、legacy env は明示OFF専用の互換に縮退。
- JoinIR Strict 着手Phase 81: `NYASH_JOINIR_STRICT=1` で代表パスのフォールバックを禁止JoinIR失敗は即エラー。dev/trace は観測のみ継続。
- **これからPhase 69+**
- wasm/Web デモライン: JoinIR ベースの軽量デモ実装。
- 最適化ライン: JoinIR の最適化パスと LLVM/ny-llvmc 統合。
- Trio 削除ライン: 完了Phase 70、LoopScopeShape SSOT
- JoinIR Strict ラインPhase 81: 代表 If/Loop/VM ブリッジについては `NYASH_JOINIR_STRICT=1` で常に JoinIR 経路のみを通すようにし、レガシー if_phi / LoopBuilder / 旧 MIR Builder は「未対応関数専用」に縮退。
---
## 1. JoinIR 第1章完了までの道のりPhase 3367 簡潔版)
### Phase 33-62: 構造 + PHI + スコープの基盤構築 ✅ 完了
- **Phase 33-34**: IfSelect/IfMerge lowering 実装、AST→JoinIR Frontend 設計・実装If/Loop/Break/Continue
- **Phase 35-36**: PHI 箱削減 HIGH/MEDIUM537行削減: if_body_local_merge / phi_invariants / LoopSnapshotMergeBox 縮退)
- **Phase 37-40**: If 側 PHI Level 1/2設計array_ext.filter 移行、collect_assigned_vars 削除)
- **Phase 41-46**: If 側 PHI Level 3NestedIfMerge、read_quoted_from、IfMerge 拡張)
- **Phase 49-56**: JoinIR Frontend 本線統合print_tokens / filter
- **Phase 57-62**: If 側 PHI 本体削減conservative.rs 縮退、If Handler 箱化、PHI Core Cleanup
**詳細**: 各 Phase の README を参照(`docs/private/roadmap2/phases/phase-*/README.md`
---
### Phase 63-67: 型ヒントライン完全実装 ✅ 完了2025-11-30
#### Phase 63-3: JoinIR 型ヒント最小配線
- `JoinInst::Select``MergePair``type_hint: Option<MirType>` 追加
- 13ファイル更新、全 JoinIR テスト PASS
#### Phase 63-4: infer_type_from_phi 縮退設計
- 型ヒント優先+従来ロジックフォールバック仕様を docs 化
- 削除条件 5/5 を定義P1: IfSelectTest, P2: read_quoted/IfMerge, P3: Method/Box
#### Phase 63-5: infer_type_from_phi 縮退実装
- `infer_type_from_phi_with_hint()` 実装(+44行
- lifecycle.rs で呼び出し経路統一
- 削除条件達成率: 3/560%
#### Phase 63-6: P1 ケース型ヒント完全実装
- `MirInstruction::Phi``type_hint` 追加21ファイル修正
- JoinIR→MIR Bridge で型ヒント伝播実装
- P1 ケースIfSelectTest.*)で JoinIR 型ヒントのみで型決定
- 削除条件達成率: 4/580%
#### Phase 64: P2 型ヒント拡大
- P2 ケースread_quoted_from, IfMerge型ヒント実装
- `is_type_hint_target()` 箱化TypeHintPolicy 萌芽)
- 削除条件達成率: 4.5/590%
#### Phase 65: P3-A/B 型ヒント実装
- P3-A: `type_inference.rs` 新設、`JoinInst::MethodCall` に型ヒントStringBox メソッド)
- P3-B: `JoinInst::NewBox` に型ヒントBox コンストラクタ)
- 代表ケースベースで削除条件 5/5 達成
#### Phase 66: P3-C ジェネリック型推論箱化
- `generic_type_resolver.rs` 新設180行
- `TypeHintPolicy::is_p3c_target()` 追加
- ArrayBox.get / MapBox.get 等のジェネリック型推論基盤確立
#### Phase 67: P3-C 実利用への一歩
- `phase67_generic_type_resolver.rs` テスト追加3テスト全 PASS
- lifecycle.rs に P3-C 経路フック追加GenericTypeResolver 優先使用)
- A/B テストで旧経路との一致確認11 tests PASS
**技術的成果**:
- JoinIR が構造 + PHI + 型ヒントの SSOT として確立
- infer_type_from_phi は P3-C フォールバック専用に縮退
- 4つの柱Structure / Scope / JoinIR / Type Hints完成
### Phase 69: MIR 決定性 & Trio 経路の整理 ✅ 一部完了2025-11-30
- 目的: LoopSnapshotMergeBox / LoopForm 周辺の Inspector/Trio 依存を整理しつつ、MIR の predecessor 順を決定的にしてフラッキーテストを解消する。
- 実績:
- 69-1: LoopSnapshotMergeBox と Trio 経路の現状を確認し、merge_exit_with_classification が LocalScopeInspectorBox を引き回しているだけであり、情報自体は LoopScopeShape/ExitAnalysis 側に揃っていることを整理。
- 69-2: `merge_exit_with_classification` から Inspector 引数を削除し、LoopScopeShape/ExitAnalysis 経由で必要な情報を取る形に縮退(約 42 行削減)。既存の 3 テストはすべて PASS。
- 69-3: `BasicBlock.predecessors``HashSet``BTreeSet` に変更するなど、MIR の predecessor イテレーションを決定的にし、これまで非決定性でフラッキーだった 2 つのループ系テストを安定化。loopform 14/14 / merge_exit 3/3 を含む関連テストはすべて PASS。
- 未了:
- 69-5: conservative.rs の docs/ 移設も今後の小フェーズとして残しておく。
- 追加完了 (Phase 70):
- 69-4: Trio 3 箱LoopVarClassBox / LoopExitLivenessBox / LocalScopeInspectorBoxを削除し、LoopScopeShape を SSOT とする構成に移行。2025-12-01 時点でコードベース再スキャン済みで、Trio 本体ファイルおよび Trio Box 直接参照は **src/mir/** から完全に除去されていることを確認名称としての「Trio」は docs の歴史メモ内にのみ残存)。
## 2. 次の一手Phase 69+
### 直近の候補タスク
- **P3-C 拡大 / If PHI 本体削除**Phase 70+ 候補)
- GenericTypeResolver 経由で全 P3-C ケースをカバー
- `infer_type_from_phi` 本体削除と if_phi.rs 大掃除
2025-12-02 10:19:07 +09:00
- **Phase 71: SelfHosting 再ブートストラップ(初回観測完了! 2025-12-02** ✅
- `docs/private/roadmap2/phases/phase-71-selfhost-reboot/README.md` で代表パス 1 本Stage3 + JoinIR 前提)と ENV 方針を整理済み。
2025-12-02 10:19:07 +09:00
- 代表パス(確定): `NYASH_FEATURES=stage3 NYASH_USE_NY_COMPILER=1 NYASH_NY_COMPILER_EMIT_ONLY=1 NYASH_SELFHOST_KEEP_RAW=1 ./tools/selfhost/selfhost_build.sh --in apps/tests/stage1_run_min.hako --run`
- **Phase 71初回実行成果 (2025-12-02)**:
- ✅ Phase 70完了直後にPhase 71代表パス実行成功
- ✅ RAW観測レイヤ活用成功 (`logs/selfhost/stageb_20251202_101623_2665649.log` 707K)
- ✅ 根本原因特定: **SSA undef (4件)** + **dev verify (1件)** が Program JSON emit失敗を引き起こしている
- ✅ JoinIR/プラグイン初期化は **問題なし** (JoinIR経路正常動作、プラグイン成功確認)
- **SSA undef詳細 (初回観測時)**:
2025-12-02 10:19:07 +09:00
1. `ParserCommonUtilsBox.trim/1` - ValueId(272)未定義
2. `ParserBox.trim/1` - ValueId(272)未定義
3. `Main._parse_number/1` - ValueId(12)未定義
4. `ParserBox.parse_block2/2` - ValueId(440)未定義
→ Phase 71-SSA での `.hako` 側整理により、現在はいずれも解消済みSSA undef 13件→0件
- **dev verify警告 (初回観測時)**: `StageBDriverBox` NewBox直後にbirth()未呼び出し
→ StageBDriverBox が static box であることを考慮し、lifecycle.rs 側の特例で警告は解消済み。
- **完了判定基準**: 観測窓としてのPhase 71は完了。代表 selfhost パスで JSON v0 emit→VM 実行(出力 `abc`)まで通ることを確認済みで、
SSA 修正は今後 StageB 他ケースと s3/parity 系にフォーカスする。
- **詳細レポート**: `docs/development/current/main/phase71-findings-20251202.md` と Phase 71-SSA 追加レポート
- quick プロファイルでは JoinIR/VM 系は緑維持を目標としつつ、selfhost_minimal / stageb_min_emit は「SSA ラインの観測窓」として赤許容。StageB/SSA 起因の赤は Phase 71-SSA 側でハンドルする。
- **Phase 72: JoinIR dev フラグ棚卸し** ✅
- `config::env::joinir_core_enabled()` / `joinir_dev_enabled()` を追加し、Core/DevOnly/Deprecated の区分を整理。
- `NYASH_JOINIR_EXPERIMENT``HAKO_JOINIR_IF_SELECT` を含む JoinIR 関連フラグの読み書きを、
`src/config/env/joinir_dev.rs` / `src/tests/helpers/joinir_env.rs` 経由の SSOT に統一(本体コードからの `std::env` 直読みを排除)。
- docs/private/roadmap2/phases/phase-72-joinir-dev-flags/README.md に一覧表と実装状況メモを追加済み。
- **Phase 73: ENV 整理・不要フラグ削除JoinIRStage3 周辺)**
- docs/private/roadmap2/phases/phase-73-env-cleanup/README.md に Stage3 / JoinIR / その他 ENV の棚卸しと Dead/Alias/Keep の分類方針を追加
- 実コードからは `parser_stage3_enabled()` / `joinir_core_enabled()` / `joinir_dev_enabled()` 経由で判定し、legacy/env 名は Alias-only 扱いとして段階的に削除候補へ寄せていく
- Stage3 旧 ENV は tools/selfhost/hako_check + JoinIR/LoopForm/PHI テスト + Stage1/SSA 代表テストBatchCからは排除済みで、残りは dev/perf 用や一部 SSA/StageB 系テストと docs の歴史メモに限定されているPhase 7311 で現状を棚卸し済み)
- **Phase 73-7: Stage3 旧 ENV の縮退**
- tools/selfhost/hako_check から `NYASH_PARSER_STAGE3` / `HAKO_PARSER_STAGE3` を順次削除し、Stage3 gate を `NYASH_FEATURES=stage3` ベースに移行開始
- Rust tests 側の Stage3 alias は次フェーズでグループごとに `NYASH_FEATURES=stage3` へ寄せる予定
- **Phase 73-8: Rust tests BatchA の Stage3 ENV 縮退**
- JoinIR/PHI 周辺の代表テストmir_loopform_* / mir_joinir_* の一部)を対象に、`NYASH_PARSER_STAGE3` / `HAKO_PARSER_STAGE3``NYASH_FEATURES=stage3` に置き換え開始
- **Phase 73-9: Rust tests BatchB の Stage3 ENV 縮退**
- 残りの JoinIR 系テストjoinir_runner_min / mir_joinir_* / joinir_json_min / joinir_vm_bridge_* / joinir/mainline_phase49についても、Stage3 旧 ENV を廃止し `NYASH_FEATURES=stage3` ベースに統一
- **wasm/Web デモライン**Phase 71 候補)
- JoinIR ベースの軽量デモ実装
- ブラウザで動く最小構成
- **最適化ライン**Phase 72+ 候補)
- JoinIR 最適化パス実装
- LLVM/ny-llvmc 統合強化
docs(phi_core): Phase 70 完全達成!Trio 完全削除 (~1,443行) ## Phase 70 実装完了 ### ✅ 完了タスク(6/6) **70-1**: loop_form_intake.rs Trio 使用削除 - 29行 → 2行(27行削減、85%削減) - LocalScopeInspectorBox / LoopVarClassBox imports 削除 - 二重分類問題解消(LoopScopeShape が SSOT) **70-2**: loop_to_join.rs 呼び出し側修正 - var_classes 引数削除 - Trio 依存ゼロ達成 **70-3**: 中間テスト - loopform 14/14 PASS ✅ - 退行なし確認 **70-4**: phi_core/mod.rs 公開面削除(ユーザー実施) - pub mod 3箇所削除 **70-5**: Trio 本体3ファイル削除(ユーザー実施) - loop_var_classifier.rs: 578行 - loop_exit_liveness.rs: 414行 - local_scope_inspector.rs: 361行 **70-6**: 最終テスト・ドキュメント - 498 passed, loopform 全 PASS ✅ - Phase 70 完了記録追加 ### 📊 削減実績 **合計削減**: **~1,443行**(Phase 69-4 見込み通り) **ファイル別**: - Trio 定義3ファイル: 1,353行削除 - loop_form_intake.rs: 27行削減 - phi_core/mod.rs: pub mod 3箇所削除 ### 🎯 達成内容 **1. 二重分類問題解消** ✅ - Before: intake_loop_form() + LoopScopeShape で2回分類 - After: LoopScopeShape のみで1回分類(SSOT 確立) **2. Trio 依存完全排除** ✅ - 外部依存: 2箇所 → 0箇所 - Trio 本体: 完全削除 **3. LoopScopeShape SSOT 確立** ✅ - 変数分類: LoopScopeShape.pinned / carriers - Exit liveness: LoopScopeShape.exit_live - 定義追跡: LoopScopeShape.variable_definitions ### 🎊 Phase 48-6 設計の完全達成 **Phase 48-6 目標**: Trio を builder.rs のみに封じ込める **Phase 70 達成**: Trio 完全削除(封じ込めから削除への昇華) **進化の完結**: 1. Phase 25.1: Option C 実装(Trio 誕生) 2. Phase 48-4: LoopScopeShape 実装(Trio 代替) 3. Phase 48-6: Trio を builder.rs に封じ込め 4. Phase 69-3: MIR 決定性修正(BTreeSet 化) 5. Phase 69-4: Trio 削除準備完了 6. **Phase 70: Trio 完全削除** 🎉 ### 🧪 テスト結果 - loopform: 14/14 PASS ✅ - 全体: 498 passed; 43 failed(既知エラーのみ、新規エラーなし) ### 📝 変更ファイル **削除**: - src/mir/phi_core/loop_var_classifier.rs (578行) - src/mir/phi_core/loop_exit_liveness.rs (414行) - src/mir/phi_core/local_scope_inspector.rs (361行) **修正**: - src/mir/join_ir/lowering/loop_form_intake.rs - src/mir/join_ir/lowering/loop_to_join.rs - src/mir/phi_core/mod.rs **ドキュメント**: - docs/development/current/main/phase69-4-trio-deletion-plan.md ### 🚀 Phase 69-70 合計削減 **~1,485行削減**: - Phase 69-2: 42行(inspector 引数削除) - Phase 70: 1,443行(Trio 完全削除) 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-02 09:45:54 +09:00
### 今後の優先タスク順selfhost + hack_check 観点の整理)
1. **Phase 71-SSA/selfhost 再ブートストラップの収束**
- 代表パスselfhost_build + stage1_run_min.hakoが JSON v0 emit→VM 実行まで通ることは確認済みとし、
以降は StageB 他ケースと s3/parity 系を「SSA ラインの観測窓」として整理していく。
docs(phi_core): Phase 70 完全達成!Trio 完全削除 (~1,443行) ## Phase 70 実装完了 ### ✅ 完了タスク(6/6) **70-1**: loop_form_intake.rs Trio 使用削除 - 29行 → 2行(27行削減、85%削減) - LocalScopeInspectorBox / LoopVarClassBox imports 削除 - 二重分類問題解消(LoopScopeShape が SSOT) **70-2**: loop_to_join.rs 呼び出し側修正 - var_classes 引数削除 - Trio 依存ゼロ達成 **70-3**: 中間テスト - loopform 14/14 PASS ✅ - 退行なし確認 **70-4**: phi_core/mod.rs 公開面削除(ユーザー実施) - pub mod 3箇所削除 **70-5**: Trio 本体3ファイル削除(ユーザー実施) - loop_var_classifier.rs: 578行 - loop_exit_liveness.rs: 414行 - local_scope_inspector.rs: 361行 **70-6**: 最終テスト・ドキュメント - 498 passed, loopform 全 PASS ✅ - Phase 70 完了記録追加 ### 📊 削減実績 **合計削減**: **~1,443行**(Phase 69-4 見込み通り) **ファイル別**: - Trio 定義3ファイル: 1,353行削除 - loop_form_intake.rs: 27行削減 - phi_core/mod.rs: pub mod 3箇所削除 ### 🎯 達成内容 **1. 二重分類問題解消** ✅ - Before: intake_loop_form() + LoopScopeShape で2回分類 - After: LoopScopeShape のみで1回分類(SSOT 確立) **2. Trio 依存完全排除** ✅ - 外部依存: 2箇所 → 0箇所 - Trio 本体: 完全削除 **3. LoopScopeShape SSOT 確立** ✅ - 変数分類: LoopScopeShape.pinned / carriers - Exit liveness: LoopScopeShape.exit_live - 定義追跡: LoopScopeShape.variable_definitions ### 🎊 Phase 48-6 設計の完全達成 **Phase 48-6 目標**: Trio を builder.rs のみに封じ込める **Phase 70 達成**: Trio 完全削除(封じ込めから削除への昇華) **進化の完結**: 1. Phase 25.1: Option C 実装(Trio 誕生) 2. Phase 48-4: LoopScopeShape 実装(Trio 代替) 3. Phase 48-6: Trio を builder.rs に封じ込め 4. Phase 69-3: MIR 決定性修正(BTreeSet 化) 5. Phase 69-4: Trio 削除準備完了 6. **Phase 70: Trio 完全削除** 🎉 ### 🧪 テスト結果 - loopform: 14/14 PASS ✅ - 全体: 498 passed; 43 failed(既知エラーのみ、新規エラーなし) ### 📝 変更ファイル **削除**: - src/mir/phi_core/loop_var_classifier.rs (578行) - src/mir/phi_core/loop_exit_liveness.rs (414行) - src/mir/phi_core/local_scope_inspector.rs (361行) **修正**: - src/mir/join_ir/lowering/loop_form_intake.rs - src/mir/join_ir/lowering/loop_to_join.rs - src/mir/phi_core/mod.rs **ドキュメント**: - docs/development/current/main/phase69-4-trio-deletion-plan.md ### 🚀 Phase 69-70 合計削減 **~1,485行削減**: - Phase 69-2: 42行(inspector 引数削除) - Phase 70: 1,443行(Trio 完全削除) 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-02 09:45:54 +09:00
- この段階では JoinIR Strict は代表 if/loop/VM ブリッジに限定し、selfhost_minimal/stageb_min_emit の赤は SSA 側の課題として扱う。
2. **Phase 7273: ENV / JoinIR dev フラグの集約完了**
- `joinir_core_enabled()` / `joinir_dev_enabled()` / `parser_stage3_enabled()` を SSOT として使い切り、tools/selfhost/hako_check/tests から旧 ENV を整理する。
docs(phi_core): Phase 70 完全達成!Trio 完全削除 (~1,443行) ## Phase 70 実装完了 ### ✅ 完了タスク(6/6) **70-1**: loop_form_intake.rs Trio 使用削除 - 29行 → 2行(27行削減、85%削減) - LocalScopeInspectorBox / LoopVarClassBox imports 削除 - 二重分類問題解消(LoopScopeShape が SSOT) **70-2**: loop_to_join.rs 呼び出し側修正 - var_classes 引数削除 - Trio 依存ゼロ達成 **70-3**: 中間テスト - loopform 14/14 PASS ✅ - 退行なし確認 **70-4**: phi_core/mod.rs 公開面削除(ユーザー実施) - pub mod 3箇所削除 **70-5**: Trio 本体3ファイル削除(ユーザー実施) - loop_var_classifier.rs: 578行 - loop_exit_liveness.rs: 414行 - local_scope_inspector.rs: 361行 **70-6**: 最終テスト・ドキュメント - 498 passed, loopform 全 PASS ✅ - Phase 70 完了記録追加 ### 📊 削減実績 **合計削減**: **~1,443行**(Phase 69-4 見込み通り) **ファイル別**: - Trio 定義3ファイル: 1,353行削除 - loop_form_intake.rs: 27行削減 - phi_core/mod.rs: pub mod 3箇所削除 ### 🎯 達成内容 **1. 二重分類問題解消** ✅ - Before: intake_loop_form() + LoopScopeShape で2回分類 - After: LoopScopeShape のみで1回分類(SSOT 確立) **2. Trio 依存完全排除** ✅ - 外部依存: 2箇所 → 0箇所 - Trio 本体: 完全削除 **3. LoopScopeShape SSOT 確立** ✅ - 変数分類: LoopScopeShape.pinned / carriers - Exit liveness: LoopScopeShape.exit_live - 定義追跡: LoopScopeShape.variable_definitions ### 🎊 Phase 48-6 設計の完全達成 **Phase 48-6 目標**: Trio を builder.rs のみに封じ込める **Phase 70 達成**: Trio 完全削除(封じ込めから削除への昇華) **進化の完結**: 1. Phase 25.1: Option C 実装(Trio 誕生) 2. Phase 48-4: LoopScopeShape 実装(Trio 代替) 3. Phase 48-6: Trio を builder.rs に封じ込め 4. Phase 69-3: MIR 決定性修正(BTreeSet 化) 5. Phase 69-4: Trio 削除準備完了 6. **Phase 70: Trio 完全削除** 🎉 ### 🧪 テスト結果 - loopform: 14/14 PASS ✅ - 全体: 498 passed; 43 failed(既知エラーのみ、新規エラーなし) ### 📝 変更ファイル **削除**: - src/mir/phi_core/loop_var_classifier.rs (578行) - src/mir/phi_core/loop_exit_liveness.rs (414行) - src/mir/phi_core/local_scope_inspector.rs (361行) **修正**: - src/mir/join_ir/lowering/loop_form_intake.rs - src/mir/join_ir/lowering/loop_to_join.rs - src/mir/phi_core/mod.rs **ドキュメント**: - docs/development/current/main/phase69-4-trio-deletion-plan.md ### 🚀 Phase 69-70 合計削減 **~1,485行削減**: - Phase 69-2: 42行(inspector 引数削除) - Phase 70: 1,443行(Trio 完全削除) 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-02 09:45:54 +09:00
- ここまでで「selfhost / hack_check / tests が同じ Stage3 + JoinIR/ENV ポリシー上に乗る」状態を目指す。
3. **Phase 80: VM/LLVM 本線の JoinIR 統一****完了**2025-12-02 c61f4bc7
- 代表 if/loop の本線化を実装。`joinir_core_enabled()` 時は JoinIR→MIR 経路が既定となり、レガシー経路は JoinIR 未対応ケース専用に縮退。
- SSOT ヘルパー(`should_try_joinir_mainline()` / `should_panic_on_joinir_failure()`)を実装。
- **Phase 82**: JOINIR_TARGETS テーブル SSOT 化93f51e40完了。
4. **Phase 81: selfhost 用 JoinIR Strictfail-fast の確立****完了**2025-12-02 a9e10d2a
- selfhost_build.sh に `--core` / `--strict` オプション追加。環境変数 `NYASH_JOINIR_CORE` / `NYASH_JOINIR_STRICT` を子プロセスに自動伝播。
- 代表パスskip_ws / trim / resolve / print_tokens / filter / Stage1/StageB 代表)が JoinIR 経由でのみ通る Strict モード実装完了。
- hack_check ラインは引き続き「Stage3 + 旧 MIR Builder + VM」の安定ルートとして維持。
feat(mir): Phase 84-4-B完了 - BoxCall型情報登録で Case D 100%解決 🎉 歴史的成果: Case D panic 9件 → 0件(100%削減達成!) Phase 84-4-B実装内容: - infer_boxcall_return_type() 新規実装(utils.rs) - ビルトイン Box メソッド戻り値型のハードコード推論 - StringBox, IntegerBox, BoolBox, ArrayBox, MapBox - Result-like Box (isOk/getValue) - QMark 対応 - Stage1CliBox - 暫定 Unknown 登録 - emit_box_or_plugin_call() の型登録ロジック強化 - plugin_method_sigs フォールバック追加 - NYASH_BOXCALL_TYPE_TRACE=1 でデバッグ出力 技術的詳細: - 責務: PhiTypeResolver が依存する base 定義型情報を生成 - 型生成レイヤー完成(Const → BoxCall → Await) - 箱理論: 型伝播レイヤーと型生成レイヤーの完全分離 検証結果: - Case D panic: 9件 → 0件 ✅ - ベースライン: 503 passed, 31 failed(変化なし) - FALLBACK_DISABLED: 497 passed, 37 failed(Case D panic なし!) 残存 4件の状況: - await/qmark/stage1_cli テストが FAILED(panic ではない) - 型推論は成功(Call 命令生成) - テスト期待値が古い(PluginInvoke 想定) Phase 84-4-C: - Await 型情報登録は不要(BoxCall 経路で解決済み) - Phase 84完了条件達成済み 関連: - Phase 84-3: PhiTypeResolver 実装(9件 → 4件) - Phase 84-2: CopyTypePropagator 実装(12件 → 9件) - Phase 84-1: Const 型注釈(15件 → 12件) 🎯 Phase 84 完全達成: 型推論システムの完全箱化成功!
2025-12-02 20:28:19 +09:00
5. **Phase 82-if-phi-retire: P3-C 完了if_phi.rs 削除ライン****継続中**
- dev フラグ `NYASH_PHI_FALLBACK_DISABLED=1``infer_type_from_phi_with_hint` の呼び出しを fail-fast 検出する経路を追加済みjoinir_dev::phi_fallback_disabled
- `lifecycle.rs` の return 型推論バグ(中間値 `const void` を見てしまう問題を修正し、Case D を 51 件 → 20 件に削減済み。
- Phase 83〜84-4 による追加削減で Case D は 0 件となり、`infer_type_from_phi*` への依存は実質的になくなった。コード上の定義削除と `phi_core::if_phi` モジュールの整理は Phase 84-5if_phi.rs 削除ライン)で実施予定。
feat(mir): Phase 84-4-B完了 - BoxCall型情報登録で Case D 100%解決 🎉 歴史的成果: Case D panic 9件 → 0件(100%削減達成!) Phase 84-4-B実装内容: - infer_boxcall_return_type() 新規実装(utils.rs) - ビルトイン Box メソッド戻り値型のハードコード推論 - StringBox, IntegerBox, BoolBox, ArrayBox, MapBox - Result-like Box (isOk/getValue) - QMark 対応 - Stage1CliBox - 暫定 Unknown 登録 - emit_box_or_plugin_call() の型登録ロジック強化 - plugin_method_sigs フォールバック追加 - NYASH_BOXCALL_TYPE_TRACE=1 でデバッグ出力 技術的詳細: - 責務: PhiTypeResolver が依存する base 定義型情報を生成 - 型生成レイヤー完成(Const → BoxCall → Await) - 箱理論: 型伝播レイヤーと型生成レイヤーの完全分離 検証結果: - Case D panic: 9件 → 0件 ✅ - ベースライン: 503 passed, 31 failed(変化なし) - FALLBACK_DISABLED: 497 passed, 37 failed(Case D panic なし!) 残存 4件の状況: - await/qmark/stage1_cli テストが FAILED(panic ではない) - 型推論は成功(Call 命令生成) - テスト期待値が古い(PluginInvoke 想定) Phase 84-4-C: - Await 型情報登録は不要(BoxCall 経路で解決済み) - Phase 84完了条件達成済み 関連: - Phase 84-3: PhiTypeResolver 実装(9件 → 4件) - Phase 84-2: CopyTypePropagator 実装(12件 → 9件) - Phase 84-1: Const 型注釈(15件 → 12件) 🎯 Phase 84 完全達成: 型推論システムの完全箱化成功!
2025-12-02 20:28:19 +09:00
6. **Phase 83-typehint-p3d: 既知メソッド戻り値型推論P3-D****完了**
- ChatGPT Pro 設計の MethodReturnHintBox を実装8ae1eabc`TypeHintPolicy``MethodReturnHintBox``TypeAnnotationBox``GenericTypeResolver` という箱構造を確立。
- BoxCall/Call/TypeOp の既知メソッド戻り値型を P3-D として吸収し、Case D を 20 件 → 15 件に削減。
- 将来の Method Registry 統一時にも差し替えやすい API になっており、型ヒントラインの構造的な整理が完了。
7. **Phase 84-1: Const 命令型アノテーション****完了**
- `src/mir/builder/emission/constant.rs` に Integer/Bool/Float/Null/Void 用の型登録を追加40dfbc68。String と同様に `value_types` へ MirType を記録。
- Case D のうち Const 命令の型欠如が原因だったグループを解消し、Case D は 15 件 → 12 件に縮小。
- 残り 12 件は Copy/PHI 経由の edge パターンLoop break/continue / If merge などに集中しており、Phase 84-2/84-3 の対象として切り出された。
8. **Phase 84-2: CopyTypePropagator による Copy 型伝播****完了**
- `src/mir/phi_core/copy_type_propagator.rs` に CopyTypePropagator 箱を追加し、MIR 関数内の `Copy { dst, src }` を固定点ループで走査して `value_types` に型を伝播。
- `lifecycle.rs` の return 型推論前に CopyTypePropagator を走らせることで、Copy チェーンだけで説明できる Case D を削減12 件 → 9 件)。
- ベースラインテストは 489 passed, 34 failed → 494 passed, 33 failed と改善。残りの Case D は await/try-catch や多段 PHI など PHI 主体のパターンに集中しており、Phase 84-3PhiTypeResolverでの限定的な PHI 型推論強化に引き継ぎ。
9. **Phase 84-3: PhiTypeResolver による PHI + Copy グラフ推論****完了**
- `src/mir/phi_core/phi_type_resolver.rs` に PhiTypeResolver 箱を追加し、`Copy`/`Phi` グラフを DFS/BFS で辿って末端の base 定義型が 1 種類に揃う場合のみ MirType を返す仕組みを実装。
- lifecycle.rs の return 型推論フローに統合し、P3-D / Const / CopyTypePropagator で埋まらない一部ケースを吸収することで Case D を 9 件 → 4 件に削減。
- 残り 4 件await 構文 / QMark 構文 / Stage1 CLI 2 テストは、BoxCall/Await/QMark の戻り値型が `value_types` に未登録なことが原因であり、PhiTypeResolver 自体の限界ではないことが Task 調査で確認されたPhase 84-4 の BoxCall/Await 型登録ラインに引き継ぎ)。
docs(phi_core): Phase 70 完全達成!Trio 完全削除 (~1,443行) ## Phase 70 実装完了 ### ✅ 完了タスク(6/6) **70-1**: loop_form_intake.rs Trio 使用削除 - 29行 → 2行(27行削減、85%削減) - LocalScopeInspectorBox / LoopVarClassBox imports 削除 - 二重分類問題解消(LoopScopeShape が SSOT) **70-2**: loop_to_join.rs 呼び出し側修正 - var_classes 引数削除 - Trio 依存ゼロ達成 **70-3**: 中間テスト - loopform 14/14 PASS ✅ - 退行なし確認 **70-4**: phi_core/mod.rs 公開面削除(ユーザー実施) - pub mod 3箇所削除 **70-5**: Trio 本体3ファイル削除(ユーザー実施) - loop_var_classifier.rs: 578行 - loop_exit_liveness.rs: 414行 - local_scope_inspector.rs: 361行 **70-6**: 最終テスト・ドキュメント - 498 passed, loopform 全 PASS ✅ - Phase 70 完了記録追加 ### 📊 削減実績 **合計削減**: **~1,443行**(Phase 69-4 見込み通り) **ファイル別**: - Trio 定義3ファイル: 1,353行削除 - loop_form_intake.rs: 27行削減 - phi_core/mod.rs: pub mod 3箇所削除 ### 🎯 達成内容 **1. 二重分類問題解消** ✅ - Before: intake_loop_form() + LoopScopeShape で2回分類 - After: LoopScopeShape のみで1回分類(SSOT 確立) **2. Trio 依存完全排除** ✅ - 外部依存: 2箇所 → 0箇所 - Trio 本体: 完全削除 **3. LoopScopeShape SSOT 確立** ✅ - 変数分類: LoopScopeShape.pinned / carriers - Exit liveness: LoopScopeShape.exit_live - 定義追跡: LoopScopeShape.variable_definitions ### 🎊 Phase 48-6 設計の完全達成 **Phase 48-6 目標**: Trio を builder.rs のみに封じ込める **Phase 70 達成**: Trio 完全削除(封じ込めから削除への昇華) **進化の完結**: 1. Phase 25.1: Option C 実装(Trio 誕生) 2. Phase 48-4: LoopScopeShape 実装(Trio 代替) 3. Phase 48-6: Trio を builder.rs に封じ込め 4. Phase 69-3: MIR 決定性修正(BTreeSet 化) 5. Phase 69-4: Trio 削除準備完了 6. **Phase 70: Trio 完全削除** 🎉 ### 🧪 テスト結果 - loopform: 14/14 PASS ✅ - 全体: 498 passed; 43 failed(既知エラーのみ、新規エラーなし) ### 📝 変更ファイル **削除**: - src/mir/phi_core/loop_var_classifier.rs (578行) - src/mir/phi_core/loop_exit_liveness.rs (414行) - src/mir/phi_core/local_scope_inspector.rs (361行) **修正**: - src/mir/join_ir/lowering/loop_form_intake.rs - src/mir/join_ir/lowering/loop_to_join.rs - src/mir/phi_core/mod.rs **ドキュメント**: - docs/development/current/main/phase69-4-trio-deletion-plan.md ### 🚀 Phase 69-70 合計削減 **~1,485行削減**: - Phase 69-2: 42行(inspector 引数削除) - Phase 70: 1,443行(Trio 完全削除) 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-02 09:45:54 +09:00
10. **Phase 84-4: BoxCall 戻り値型登録Await/QMark 含む)****完了**
- `src/mir/builder/utils.rs``infer_boxcall_return_type()` ヘルパーを追加し、StringBox/IntegerBox/BoolBox/ArrayBox/MapBox/Result-likeQMark 相当)/Stage1CliBox など計 27 メソッドの戻り値型を一元管理。
- BoxCall lowering 経路emit_box_or_plugin_call 相当)から `infer_boxcall_return_type()` を呼び出し、戻り値 ValueId に対応する MirType を `value_types` に登録。
- Await/QMark 系は BoxCall 経路の型登録で全て解消され、追加の Await 専用実装は不要。
feat(box_factory): Phase 86 BoxFactory Priority normalization Phase 86: BoxFactory Priority 正常化プロジェクト完了 目的: - BoxFactory のデフォルトポリシーを BuiltinFirst から StrictPluginFirst に変更 - プラグイン版 StringBox/ArrayBox/MapBox が正常に使用できるよう正常化 - Phase 85 (Ring0/Ring1-Core 境界設計) の土台準備 実装内容: 1. ドキュメント作成 - docs/development/current/main/factory_priority.md: 完全仕様文書化 2. コード修正 (1行のみ) - UnifiedBoxRegistry::new() が with_env_policy() を使用 - デフォルトポリシーが StrictPluginFirst に変更 3. テスト追加 (5件, 全パス) - test_default_policy_is_strict_plugin_first: デフォルトポリシー確認 - test_env_policy_override: 環境変数制御確認 - test_reserved_type_protection: 予約型保護動作確認 - test_plugin_override_with_env: 予約型 override 確認 - test_non_reserved_plugin_priority: 非予約型プラグイン優先確認 効果: - ✅ プラグイン版 StringBox/ArrayBox/MapBox が正常に使用可能 - ✅ core_required Box の予約名保護維持 - ✅ 環境変数による柔軟な制御が可能 - ✅ テスト改善: 500→506 passed, 34→33 failed (+6 passed, -1 failed) core_required Box リスト (暫定): - Core value types: StringBox, IntegerBox, BoolBox, FloatBox, NullBox - Core containers: ArrayBox, MapBox, ResultBox - Core method indirection: MethodBox 環境変数: - NYASH_BOX_FACTORY_POLICY: ポリシー選択 (default: strict_plugin_first) - NYASH_USE_PLUGIN_BUILTINS: core_required override 許可 - NYASH_PLUGIN_OVERRIDE_TYPES: 個別 Box override 許可 Phase 85 準備: - Ring0/Ring1-Core 境界設計の土台が整った - ConsoleBox の扱いは Phase 85 で最終決定 完了条件: - ✅ factory_priority.md 作成完了 - ✅ UnifiedBoxRegistry::new() 修正完了 - ✅ デフォルトポリシー StrictPluginFirst 確定 - ✅ テスト 5件追加・全パス - ✅ CURRENT_TASK.md 更新完了 - ✅ Phase 85 README 準備完了 参考: - 設計文書: docs/development/current/main/factory_priority.md - Phase 85 計画: docs/private/roadmap2/phases/phase-85-ring0-runtime/README.md 🎉 Phase 86 完了!次は Phase 85 で Ring0/Ring1-Core 境界の文書化へ
2025-12-02 21:52:18 +09:00
- `NYASH_PHI_FALLBACK_DISABLED=1 cargo test --release --lib` 実行時の Case D panic は 4 件 → 0 件となり、Case D 完全解消を達成。型生成Const/BoxCall・型伝播CopyTypePropagator/PhiTypeResolver・統合GenericTypeResolverの 3 層構造が箱として完成し、if_phi フォールバック削除に進める状態になったPhase 84-5 / 82 の最終仕上げ)。
11. **Phase 85-ring0-runtime: Ring0/Ring1/Plugin 層の設計整理****設計中**
- Ring0 は Box を知らない最小カーネル APIMem/Io/Time/Log/Fs/Thread 等)に限定し、実装は `Ring0Context` + adapter 1 箇所に集約する方針を docs に固定済み。
- Ring1-coreStringBox/ArrayBox/MapBox/FileBox/ConsoleBox 等)と ring1-optional/selfhost/user_plugin を 4 層に分類し、「core_required は静的必須セット、optional と user は PluginHost の上に載る」設計を言語化済み。
docs(runtime): Phase 99 ログ/出力ポリシー確定 - 3層設計の文書化完成 ## Phase 99 完了項目(ドキュメント設計フェーズ) - ✅ logging_policy.md 新規作成(312行) - ✅ ring0-inventory.md 更新(455行) - ✅ core_boxes_design.md Section 15.6-A 追記(+58行) - ✅ CURRENT_TASK.md Phase 85 セクション更新 ## 確定した3層ログ/出力設計 【Ring0.log】(OS API層) - 用途: ランタイム/OS内部ログ - 対象: 開発者向けデバッグ・計測・内部状態 - API: ring0.log.debug/info/warn/error(...) 【ConsoleService】(Box層・ユーザー向け) - 用途: CLIの直接的な出力(ユーザー向けメッセージ) - 対象: エンドユーザー - アクセス: console_println! マクロ 【素のprintln!/eprintln!】(制限用途) - 用途: テスト・一時デバッグのみ限定 - テスト内: 約299箇所そのまま許可 - 本番経路: 撤退すべき ## println!/eprintln! 残件分類(1477箇所) - user-facing: ~366箇所(HIGH)→ console_println! - dev-debug: TBD(MEDIUM)→ Ring0.log or dev_* macros - test: ~299箇所(LOW)→ そのまま許可 - internal: ~812箇所(TBD) ## 設計の価値 - **コード変更なし**: リスク最小(ドキュメントのみ) - **後工程の基盤**: Phase 100-101で残り~366箇所を片付け可能 - **Fail-Fast原則**: マクロ方針でエラーメッセージは確実に出力 - **段階的移行**: Graceful Degradation パターンで初期化前後を対応 ## 新規ドキュメント構成 logging_policy.md: - Section 1: 3層の役割分担 - Section 2: Macroポリシー - Section 3: テスト内println!の扱い - Section 4: 完全統合の完了条件 - Section 5: 設計原則 - Section 6: 関連ドキュメント ring0-inventory.md: - Section 1: Ring0.log利用状況 - Section 2: println! 残件分類(4カテゴリ) - Section 3: Ring0.log活用計画 - Section 4-8: 配布状況・ロードマップ・コマンド・履歴・成功基準 ## AI協働開発の成功例 - 設計と実装の分離(Phase 99=設計、Phase 100+=実装) - 段階的アプローチ(80/20ルール:完璧より進捗) - ドキュメント優先(コードより先に設計を固める) ## Phase 85-99 総括 - Phase 95.5: StringService/ConsoleService実装 - Phase 96-96.5: ArrayService/MapService & コード整理 - Phase 97: IntegerService/BoolService(#[allow(dead_code)] 根絶) - Phase 98-98.5: ConsoleService代表パス拡張(7箇所) - Phase 99: ログ/出力ポリシー確定(設計フェーズ) ✅ 次: Phase 100-101(user-facing移行、~366箇所段階的実装) 🎊 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-03 11:31:35 +09:00
- `docs/development/current/main/ring0-inventory.md` に println!/eprintln! や fs/time/thread を含む Ring0 候補呼び出し、Box/プラグイン/カーネル実装数の調査結果をまとめ、Phase 88/90 で代表パスを Ring0Context に移行済み(残りは Phase 99 以降の段階移行対象)。
- Phase 8797 で CoreBoxId/CoreMethodId/CoreServices/PluginHost/Adapter/Service API の実装とテストが完了し、Box 名・メソッド名と core_required Box の初期化は `src/runtime/core_box_ids.rs``src/runtime/core_services.rs` に集約された。Phase 98 で Console/String/Array/Map の代表パス 7 箇所が CoreServices 経由に切り替わり、今後の ring0/ring1-core 変更はこの SSOT に対してのみ行えばよい状態になっている。
feat(phase95.5): Ring0統合完了 - Adapter整理とコード簡略化 Phase 95.5完全達成 - ConsoleService/StringService Ring0直結化 ### 実装成果 - ✅ ConsoleBoxAdapter Ring0直結(println → log.info, print → io.stdout_write) - ✅ StringBoxAdapter 純粋関数化(Box状態不要) - ✅ #[allow(dead_code)] 6→4箇所削減(2削除) - ✅ PluginHost初期化簡略化(存在確認のみ) - ✅ テスト14/14 PASS(100%) ### 変更ファイル - src/runtime/core_services.rs: ConsoleBoxAdapter/StringBoxAdapter unit struct化 - src/runtime/plugin_host.rs: 初期化ロジック簡略化(create_box → has_type) - docs/development/current/main/core_boxes_design.md: Section 12追加 - CURRENT_TASK.md: Phase 95.5成果記録 ### 設計パターン確立 **2つのAdapterパターン**: 1. Ring0直結型(ConsoleService): OS API thin wrapper 2. 純粋関数型(StringService): Box状態不要 **将来実装方針**: - ArrayService/MapService: 状態管理必要 → Box保持 - IntegerService/BoolService: 純粋関数 → Box不要 ### 技術的成果 - Ring0統合完成(ログ経路統一: Ring0 → Ring1-Core → 実行パス) - コード簡略化(不要なinnerフィールド削除) - 設計明確化(Adapterの役割を2パターンに整理) - テスト容易性向上(Ring0モック可能) ### 削減統計 - #[allow(dead_code)]: 2箇所削除 - innerフィールド: 2個削除 - Box依存: 2箇所削除 ### 次のステップ Phase 96: ArrayService/MapService実装(downcastパターン) 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-03 10:15:23 +09:00
- **Phase 95.5: Ring0 統合完了**2025-12-03
- ✅ ConsoleService が Ring0Context に直結println → Ring0Context.log.info, print → Ring0Context.io.stdout_write
- ✅ StringService が純粋関数化Box 状態不要)
- ✅ #[allow(dead_code)] 削減: 6箇所 → 4箇所2削減
- ✅ ログ経路統一: Ring0 → Ring1-Core → 実行パス
- **設計原則確立**: Ring0 直結型ConsoleServiceと純粋関数型StringServiceの2パターン
- **次のステップ**: Phase 96 で ArrayService/MapService 実装状態管理必要、代表パス拡大5-10箇所
docs(runtime): Phase 99 ログ/出力ポリシー確定 - 3層設計の文書化完成 ## Phase 99 完了項目(ドキュメント設計フェーズ) - ✅ logging_policy.md 新規作成(312行) - ✅ ring0-inventory.md 更新(455行) - ✅ core_boxes_design.md Section 15.6-A 追記(+58行) - ✅ CURRENT_TASK.md Phase 85 セクション更新 ## 確定した3層ログ/出力設計 【Ring0.log】(OS API層) - 用途: ランタイム/OS内部ログ - 対象: 開発者向けデバッグ・計測・内部状態 - API: ring0.log.debug/info/warn/error(...) 【ConsoleService】(Box層・ユーザー向け) - 用途: CLIの直接的な出力(ユーザー向けメッセージ) - 対象: エンドユーザー - アクセス: console_println! マクロ 【素のprintln!/eprintln!】(制限用途) - 用途: テスト・一時デバッグのみ限定 - テスト内: 約299箇所そのまま許可 - 本番経路: 撤退すべき ## println!/eprintln! 残件分類(1477箇所) - user-facing: ~366箇所(HIGH)→ console_println! - dev-debug: TBD(MEDIUM)→ Ring0.log or dev_* macros - test: ~299箇所(LOW)→ そのまま許可 - internal: ~812箇所(TBD) ## 設計の価値 - **コード変更なし**: リスク最小(ドキュメントのみ) - **後工程の基盤**: Phase 100-101で残り~366箇所を片付け可能 - **Fail-Fast原則**: マクロ方針でエラーメッセージは確実に出力 - **段階的移行**: Graceful Degradation パターンで初期化前後を対応 ## 新規ドキュメント構成 logging_policy.md: - Section 1: 3層の役割分担 - Section 2: Macroポリシー - Section 3: テスト内println!の扱い - Section 4: 完全統合の完了条件 - Section 5: 設計原則 - Section 6: 関連ドキュメント ring0-inventory.md: - Section 1: Ring0.log利用状況 - Section 2: println! 残件分類(4カテゴリ) - Section 3: Ring0.log活用計画 - Section 4-8: 配布状況・ロードマップ・コマンド・履歴・成功基準 ## AI協働開発の成功例 - 設計と実装の分離(Phase 99=設計、Phase 100+=実装) - 段階的アプローチ(80/20ルール:完璧より進捗) - ドキュメント優先(コードより先に設計を固める) ## Phase 85-99 総括 - Phase 95.5: StringService/ConsoleService実装 - Phase 96-96.5: ArrayService/MapService & コード整理 - Phase 97: IntegerService/BoolService(#[allow(dead_code)] 根絶) - Phase 98-98.5: ConsoleService代表パス拡張(7箇所) - Phase 99: ログ/出力ポリシー確定(設計フェーズ) ✅ 次: Phase 100-101(user-facing移行、~366箇所段階的実装) 🎊 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-03 11:31:35 +09:00
- **Phase 96: ArrayService/MapService 実装**2025-12-03
- ✅ ArrayService/MapService 実装完了downcast型パターン
- ✅ #[allow(dead_code)] 根絶: 4箇所 → 0箇所完全削減
- ✅ 3つのサービス実装パターン確立Ring0直結/純粋関数/downcast型
- **Phase 97: IntegerService/BoolService 実装**2025-12-03
- ✅ IntegerService/BoolService 実装完了
- ✅ CoreServices 5種類完成Console/String/Array/Map/Integer/Bool
- ✅ プリミティブ型の完全統合達成
- **Phase 98: ConsoleService 代表パス拡張**2025-12-03
- ✅ console_println! マクロ導入Graceful Degradation 実装)
- ✅ 7箇所で println!/eprintln! → console_println! 移行完了
- ✅ selfhost/VM 実行経路の代表パスカバー達成
- **Phase 98.5: Arc 簡略化 & コメント統一**2025-12-03
- ✅ #[allow(clippy::arc_with_non_send_sync)] 削減: 4箇所 → 1箇所
- ✅ 全 CoreServices に統一コメント追加
- ✅ コード品質向上Clippy warnings 削減)
feat(runtime): Phase 100 user-facing 出力の ConsoleService 完全統一 - 29箇所完了 ## Phase 100 完了項目 - ✅ selfhost.rs: 6箇所 → console_println! - ✅ llvm.rs: 23箇所(主要メッセージ) → console_println! - ✅ 全テストPASS(core_services: 11, plugin_host: 7) - ✅ ドキュメント更新完了 ## 置き換え箇所(29箇所) **selfhost.rs**(6箇所): - Line 57: CoreInitError 出力 - Lines 194/363/418/519/570: Result 出力 **llvm.rs**(23箇所、ユーザー向けメッセージのみ): - エラーメッセージ(❌): ファイル読み込み、using/parse エラー - 成功メッセージ(📊): MIR コンパイル成功 - LLVM/harness 関連エラー - 実行結果出力 - Mock LLVM メッセージ ## 意図的に除外(Phase 101 対象) - llvm.rs の `[joinir/llvm]`, `[parse/context]` デバッグログ - hack_check: .hako アプリ(Nyash言語の ConsoleBox 経由) - bench.rs: テスト・性能表示(dev-debug) - mir.rs: 内部 MIR ダンプ(dev-debug) ## 技術的成果 - selfhost/LLVM runner のユーザー向けメッセージを ConsoleService に統一 - Phase 99 で確立したログ/出力ポリシーを実装レベルで実現 - デバッグログとユーザー向け出力の明確な分離 - Graceful Degradation パターンの実用確認 ## 統計 - Phase 98: 7箇所 - Phase 100: 29箇所 - **合計**: 36箇所で ConsoleService 経由に移行完了 - 残り user-facing: ~330箇所(Phase 101-102 で段階的拡張) ## ドキュメント更新 - logging_policy.md: Section 7 追加(Phase 100 実装完了記録) - ring0-inventory.md: Category 1 更新(Phase 100 進捗反映) - CURRENT_TASK.md: Phase 85 セクション追記 ## Phase 85-100 総括 - Phase 95.5-97: CoreServices 6個完全実装(String/Integer/Bool/Array/Map/Console) - Phase 98-98.5: ConsoleService 代表パス拡張(7箇所) - Phase 99: ログ/出力ポリシー確定(3層設計文書化) - Phase 100: user-facing 出力の ConsoleService 化(29箇所) ✅ 次: Phase 101(dev-debug/test/internal 出力の整理、Ring0.log 活用) 🎊 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-03 11:55:14 +09:00
- **Phase 99: ログ/出力ポリシー確定**2025-12-03
docs(runtime): Phase 99 ログ/出力ポリシー確定 - 3層設計の文書化完成 ## Phase 99 完了項目(ドキュメント設計フェーズ) - ✅ logging_policy.md 新規作成(312行) - ✅ ring0-inventory.md 更新(455行) - ✅ core_boxes_design.md Section 15.6-A 追記(+58行) - ✅ CURRENT_TASK.md Phase 85 セクション更新 ## 確定した3層ログ/出力設計 【Ring0.log】(OS API層) - 用途: ランタイム/OS内部ログ - 対象: 開発者向けデバッグ・計測・内部状態 - API: ring0.log.debug/info/warn/error(...) 【ConsoleService】(Box層・ユーザー向け) - 用途: CLIの直接的な出力(ユーザー向けメッセージ) - 対象: エンドユーザー - アクセス: console_println! マクロ 【素のprintln!/eprintln!】(制限用途) - 用途: テスト・一時デバッグのみ限定 - テスト内: 約299箇所そのまま許可 - 本番経路: 撤退すべき ## println!/eprintln! 残件分類(1477箇所) - user-facing: ~366箇所(HIGH)→ console_println! - dev-debug: TBD(MEDIUM)→ Ring0.log or dev_* macros - test: ~299箇所(LOW)→ そのまま許可 - internal: ~812箇所(TBD) ## 設計の価値 - **コード変更なし**: リスク最小(ドキュメントのみ) - **後工程の基盤**: Phase 100-101で残り~366箇所を片付け可能 - **Fail-Fast原則**: マクロ方針でエラーメッセージは確実に出力 - **段階的移行**: Graceful Degradation パターンで初期化前後を対応 ## 新規ドキュメント構成 logging_policy.md: - Section 1: 3層の役割分担 - Section 2: Macroポリシー - Section 3: テスト内println!の扱い - Section 4: 完全統合の完了条件 - Section 5: 設計原則 - Section 6: 関連ドキュメント ring0-inventory.md: - Section 1: Ring0.log利用状況 - Section 2: println! 残件分類(4カテゴリ) - Section 3: Ring0.log活用計画 - Section 4-8: 配布状況・ロードマップ・コマンド・履歴・成功基準 ## AI協働開発の成功例 - 設計と実装の分離(Phase 99=設計、Phase 100+=実装) - 段階的アプローチ(80/20ルール:完璧より進捗) - ドキュメント優先(コードより先に設計を固める) ## Phase 85-99 総括 - Phase 95.5: StringService/ConsoleService実装 - Phase 96-96.5: ArrayService/MapService & コード整理 - Phase 97: IntegerService/BoolService(#[allow(dead_code)] 根絶) - Phase 98-98.5: ConsoleService代表パス拡張(7箇所) - Phase 99: ログ/出力ポリシー確定(設計フェーズ) ✅ 次: Phase 100-101(user-facing移行、~366箇所段階的実装) 🎊 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-03 11:31:35 +09:00
- ✅ logging_policy.md 新規作成3層分離設計・マクロポリシー・テスト方針を文書化
- ✅ ring0-inventory.md 更新println! 残件分類・Ring0.log 活用計画を記載)
- ✅ core_boxes_design.md Section 15.6-A 追記(統一設計の補強)
- ✅ 残り ~1477 箇所の println!/eprintln! を「後工程で片付けられる設計」に整理
- **設計フェーズのみ**: コード変更なし、docs ベースでポリシー確定
feat(runtime): Phase 101-A dev-debug ログの Ring0.log 統一 - 34箇所完了 ## Phase 101-A 完了項目 - ✅ llvm.rs: 13箇所([joinir/llvm], [parse/context]) → Ring0.log - ✅ loop_form.rs: [loopform] 系ログ → Ring0.log - ✅ loopform_builder.rs: 16箇所([loopform/prepare], [loopform/seal_phis]) → Ring0.log - ✅ loop_snapshot_merge.rs: 5箇所([Option C]) → Ring0.log - ✅ 全テストPASS(ビルド成功) ## 置き換え箇所(34箇所) **llvm.rs**(13箇所): - [joinir/llvm] JoinIR 実験パスログ(12箇所) - [parse/context] プリロードファイルリスト(1箇所) **loop_form.rs**(複数箇所): - [loopform] 基本ログ - [loopform/condition] 条件式処理 - [loopform/writes] 変数書き込み収集 **loopform_builder.rs**(16箇所): - [loopform/prepare] 構造準備 - [loopform/seal_phis] PHI シーリング処理 **loop_snapshot_merge.rs**(5箇所): - [Option C] Exit PHI 分類 - [Option C] 変数解析 ## 技術的成果 - Ring0.log で dev-debug ログを一元管理 - stderr の cleanness 向上(ユーザー向けメッセージのみ) - 環境に応じた出力制御が可能(NYASH_LOOPFORM_DEBUG等) - Phase 99-100 で確立した 3層設計を実装レベルで完成 ## 実装パターン ```rust // Before eprintln!("[loopform] variable_map: {:?}", map); // After crate::runtime::get_global_ring0().log.debug(&format!( "[loopform] variable_map: {:?}", map )); ``` ## 統計 - Phase 98: 7箇所(ConsoleService) - Phase 100: 29箇所(ConsoleService) - Phase 101-A: 34箇所(Ring0.log) - **合計**: 70箇所で統一(ConsoleService/Ring0.log) - 残り: ~905箇所(test含む) ## ドキュメント更新 - logging_policy.md: Section 7-A 追加(Phase 101-A 実装記録) - ring0-inventory.md: Category 2 更新(dev-debug 進捗反映) - CURRENT_TASK.md: Phase 85 セクション追記 ## Phase 85-101-A 総括 - Phase 95.5-97: CoreServices 6個完全実装(String/Integer/Bool/Array/Map/Console) - Phase 98-98.5: ConsoleService 代表パス拡張(7箇所) - Phase 99: ログ/出力ポリシー確定(3層設計文書化) - Phase 100: user-facing 出力の ConsoleService 化(29箇所) - Phase 101-A: dev-debug ログの Ring0.log 統一(34箇所) ✅ 次: Phase 101-B(internal/test ログの整理、別検討) 🎊 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-03 12:25:32 +09:00
- **Phase 100: user-facing 出力の CoreServices 化**2025-12-03
feat(runtime): Phase 100 user-facing 出力の ConsoleService 完全統一 - 29箇所完了 ## Phase 100 完了項目 - ✅ selfhost.rs: 6箇所 → console_println! - ✅ llvm.rs: 23箇所(主要メッセージ) → console_println! - ✅ 全テストPASS(core_services: 11, plugin_host: 7) - ✅ ドキュメント更新完了 ## 置き換え箇所(29箇所) **selfhost.rs**(6箇所): - Line 57: CoreInitError 出力 - Lines 194/363/418/519/570: Result 出力 **llvm.rs**(23箇所、ユーザー向けメッセージのみ): - エラーメッセージ(❌): ファイル読み込み、using/parse エラー - 成功メッセージ(📊): MIR コンパイル成功 - LLVM/harness 関連エラー - 実行結果出力 - Mock LLVM メッセージ ## 意図的に除外(Phase 101 対象) - llvm.rs の `[joinir/llvm]`, `[parse/context]` デバッグログ - hack_check: .hako アプリ(Nyash言語の ConsoleBox 経由) - bench.rs: テスト・性能表示(dev-debug) - mir.rs: 内部 MIR ダンプ(dev-debug) ## 技術的成果 - selfhost/LLVM runner のユーザー向けメッセージを ConsoleService に統一 - Phase 99 で確立したログ/出力ポリシーを実装レベルで実現 - デバッグログとユーザー向け出力の明確な分離 - Graceful Degradation パターンの実用確認 ## 統計 - Phase 98: 7箇所 - Phase 100: 29箇所 - **合計**: 36箇所で ConsoleService 経由に移行完了 - 残り user-facing: ~330箇所(Phase 101-102 で段階的拡張) ## ドキュメント更新 - logging_policy.md: Section 7 追加(Phase 100 実装完了記録) - ring0-inventory.md: Category 1 更新(Phase 100 進捗反映) - CURRENT_TASK.md: Phase 85 セクション追記 ## Phase 85-100 総括 - Phase 95.5-97: CoreServices 6個完全実装(String/Integer/Bool/Array/Map/Console) - Phase 98-98.5: ConsoleService 代表パス拡張(7箇所) - Phase 99: ログ/出力ポリシー確定(3層設計文書化) - Phase 100: user-facing 出力の ConsoleService 化(29箇所) ✅ 次: Phase 101(dev-debug/test/internal 出力の整理、Ring0.log 活用) 🎊 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-03 11:55:14 +09:00
- ✅ selfhost.rs: 6箇所 → console_println!CoreInitError, Result 出力)
- ✅ llvm.rs: 23箇所 → console_println!(エラー、成功メッセージ、実行結果)
- ✅ 合計 29箇所完了Phase 98: 7 + Phase 100: 29 = 36箇所
- ✅ cargo build --release 成功、全テスト PASScore_services: 11, plugin_host: 7
- ✅ デバッグログとユーザー向け出力の明確な分離達成
feat(runtime): Phase 101-A dev-debug ログの Ring0.log 統一 - 34箇所完了 ## Phase 101-A 完了項目 - ✅ llvm.rs: 13箇所([joinir/llvm], [parse/context]) → Ring0.log - ✅ loop_form.rs: [loopform] 系ログ → Ring0.log - ✅ loopform_builder.rs: 16箇所([loopform/prepare], [loopform/seal_phis]) → Ring0.log - ✅ loop_snapshot_merge.rs: 5箇所([Option C]) → Ring0.log - ✅ 全テストPASS(ビルド成功) ## 置き換え箇所(34箇所) **llvm.rs**(13箇所): - [joinir/llvm] JoinIR 実験パスログ(12箇所) - [parse/context] プリロードファイルリスト(1箇所) **loop_form.rs**(複数箇所): - [loopform] 基本ログ - [loopform/condition] 条件式処理 - [loopform/writes] 変数書き込み収集 **loopform_builder.rs**(16箇所): - [loopform/prepare] 構造準備 - [loopform/seal_phis] PHI シーリング処理 **loop_snapshot_merge.rs**(5箇所): - [Option C] Exit PHI 分類 - [Option C] 変数解析 ## 技術的成果 - Ring0.log で dev-debug ログを一元管理 - stderr の cleanness 向上(ユーザー向けメッセージのみ) - 環境に応じた出力制御が可能(NYASH_LOOPFORM_DEBUG等) - Phase 99-100 で確立した 3層設計を実装レベルで完成 ## 実装パターン ```rust // Before eprintln!("[loopform] variable_map: {:?}", map); // After crate::runtime::get_global_ring0().log.debug(&format!( "[loopform] variable_map: {:?}", map )); ``` ## 統計 - Phase 98: 7箇所(ConsoleService) - Phase 100: 29箇所(ConsoleService) - Phase 101-A: 34箇所(Ring0.log) - **合計**: 70箇所で統一(ConsoleService/Ring0.log) - 残り: ~905箇所(test含む) ## ドキュメント更新 - logging_policy.md: Section 7-A 追加(Phase 101-A 実装記録) - ring0-inventory.md: Category 2 更新(dev-debug 進捗反映) - CURRENT_TASK.md: Phase 85 セクション追記 ## Phase 85-101-A 総括 - Phase 95.5-97: CoreServices 6個完全実装(String/Integer/Bool/Array/Map/Console) - Phase 98-98.5: ConsoleService 代表パス拡張(7箇所) - Phase 99: ログ/出力ポリシー確定(3層設計文書化) - Phase 100: user-facing 出力の ConsoleService 化(29箇所) - Phase 101-A: dev-debug ログの Ring0.log 統一(34箇所) ✅ 次: Phase 101-B(internal/test ログの整理、別検討) 🎊 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-03 12:25:32 +09:00
- **除外**: llvm.rs の `[joinir/llvm]`, `[parse/context]` デバッグログPhase 101-A で対応)
feat(runtime): Phase 100 user-facing 出力の ConsoleService 完全統一 - 29箇所完了 ## Phase 100 完了項目 - ✅ selfhost.rs: 6箇所 → console_println! - ✅ llvm.rs: 23箇所(主要メッセージ) → console_println! - ✅ 全テストPASS(core_services: 11, plugin_host: 7) - ✅ ドキュメント更新完了 ## 置き換え箇所(29箇所) **selfhost.rs**(6箇所): - Line 57: CoreInitError 出力 - Lines 194/363/418/519/570: Result 出力 **llvm.rs**(23箇所、ユーザー向けメッセージのみ): - エラーメッセージ(❌): ファイル読み込み、using/parse エラー - 成功メッセージ(📊): MIR コンパイル成功 - LLVM/harness 関連エラー - 実行結果出力 - Mock LLVM メッセージ ## 意図的に除外(Phase 101 対象) - llvm.rs の `[joinir/llvm]`, `[parse/context]` デバッグログ - hack_check: .hako アプリ(Nyash言語の ConsoleBox 経由) - bench.rs: テスト・性能表示(dev-debug) - mir.rs: 内部 MIR ダンプ(dev-debug) ## 技術的成果 - selfhost/LLVM runner のユーザー向けメッセージを ConsoleService に統一 - Phase 99 で確立したログ/出力ポリシーを実装レベルで実現 - デバッグログとユーザー向け出力の明確な分離 - Graceful Degradation パターンの実用確認 ## 統計 - Phase 98: 7箇所 - Phase 100: 29箇所 - **合計**: 36箇所で ConsoleService 経由に移行完了 - 残り user-facing: ~330箇所(Phase 101-102 で段階的拡張) ## ドキュメント更新 - logging_policy.md: Section 7 追加(Phase 100 実装完了記録) - ring0-inventory.md: Category 1 更新(Phase 100 進捗反映) - CURRENT_TASK.md: Phase 85 セクション追記 ## Phase 85-100 総括 - Phase 95.5-97: CoreServices 6個完全実装(String/Integer/Bool/Array/Map/Console) - Phase 98-98.5: ConsoleService 代表パス拡張(7箇所) - Phase 99: ログ/出力ポリシー確定(3層設計文書化) - Phase 100: user-facing 出力の ConsoleService 化(29箇所) ✅ 次: Phase 101(dev-debug/test/internal 出力の整理、Ring0.log 活用) 🎊 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-03 11:55:14 +09:00
- **次のステップ**: Phase 101-102 で残り ~330箇所の段階的移行
feat(runtime): Phase 101-A dev-debug ログの Ring0.log 統一 - 34箇所完了 ## Phase 101-A 完了項目 - ✅ llvm.rs: 13箇所([joinir/llvm], [parse/context]) → Ring0.log - ✅ loop_form.rs: [loopform] 系ログ → Ring0.log - ✅ loopform_builder.rs: 16箇所([loopform/prepare], [loopform/seal_phis]) → Ring0.log - ✅ loop_snapshot_merge.rs: 5箇所([Option C]) → Ring0.log - ✅ 全テストPASS(ビルド成功) ## 置き換え箇所(34箇所) **llvm.rs**(13箇所): - [joinir/llvm] JoinIR 実験パスログ(12箇所) - [parse/context] プリロードファイルリスト(1箇所) **loop_form.rs**(複数箇所): - [loopform] 基本ログ - [loopform/condition] 条件式処理 - [loopform/writes] 変数書き込み収集 **loopform_builder.rs**(16箇所): - [loopform/prepare] 構造準備 - [loopform/seal_phis] PHI シーリング処理 **loop_snapshot_merge.rs**(5箇所): - [Option C] Exit PHI 分類 - [Option C] 変数解析 ## 技術的成果 - Ring0.log で dev-debug ログを一元管理 - stderr の cleanness 向上(ユーザー向けメッセージのみ) - 環境に応じた出力制御が可能(NYASH_LOOPFORM_DEBUG等) - Phase 99-100 で確立した 3層設計を実装レベルで完成 ## 実装パターン ```rust // Before eprintln!("[loopform] variable_map: {:?}", map); // After crate::runtime::get_global_ring0().log.debug(&format!( "[loopform] variable_map: {:?}", map )); ``` ## 統計 - Phase 98: 7箇所(ConsoleService) - Phase 100: 29箇所(ConsoleService) - Phase 101-A: 34箇所(Ring0.log) - **合計**: 70箇所で統一(ConsoleService/Ring0.log) - 残り: ~905箇所(test含む) ## ドキュメント更新 - logging_policy.md: Section 7-A 追加(Phase 101-A 実装記録) - ring0-inventory.md: Category 2 更新(dev-debug 進捗反映) - CURRENT_TASK.md: Phase 85 セクション追記 ## Phase 85-101-A 総括 - Phase 95.5-97: CoreServices 6個完全実装(String/Integer/Bool/Array/Map/Console) - Phase 98-98.5: ConsoleService 代表パス拡張(7箇所) - Phase 99: ログ/出力ポリシー確定(3層設計文書化) - Phase 100: user-facing 出力の ConsoleService 化(29箇所) - Phase 101-A: dev-debug ログの Ring0.log 統一(34箇所) ✅ 次: Phase 101-B(internal/test ログの整理、別検討) 🎊 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-03 12:25:32 +09:00
- **Phase 101-A: dev-debug ログの Ring0.log 統一**2025-12-03← NEW
- ✅ llvm.rs: 13箇所 → Ring0.log`[joinir/llvm]`, `[parse/context]`
- ✅ loop_form.rs: 全 `[loopform]` ログ → Ring0.log
- ✅ phi_core: 21箇所 → Ring0.log`[loopform/prepare]`, `[loopform/seal_phis]`, `[Option C]`
- ✅ 合計 34箇所完了llvm: 13 + loop_form: すべて + phi_core: 21
- ✅ cargo build --release 成功(警告のみ、エラーなし)
- ✅ VM実行テスト: loop_min_while.hako 正常動作
- ✅ Ring0.log で dev-debug ログを一元管理達成
- **環境変数**: `NYASH_LOOPFORM_DEBUG=1`, `NYASH_OPTION_C_DEBUG=1` で制御
- **次のステップ**: Phase 101-B/C で残り ~585箇所の段階的移行
- **Phase 101-B: internal/test ログ整理Rust 側)**2025-12-04
- ✅ internal/dev println!/eprintln! 113箇所を Ring0.log に移行provider_lock / plugin_loader_unified / type_meta / deprecations / leak_tracker / provider_verify / scheduler / gc_controller / box_registry / plugin_loader_v2 周辺 / runner trace / mir verifier / mir core basic_block/control_form/hints/effect/printer/optimizer / loop_builder/phi_ops / builder/type_registry / region/observer / extern_functions / plugin types finalize trace / joinir_if_phi_selector / observe/types+resolve / join_ir_vm_bridge_dispatch run_generic / loop_builder/control など)
- ✅ logging_policy.md / ring0-inventory.md にテスト出力許容ポリシーと残件概算を追記(残 ~475495
- ⏭️ 残り internal/dev ログは Phase 101-C 以降で段階的に処理user-facing/.hako は別ライン)
- **Phase 104: .hako側ロギング設計**2025-12-04
- ✅ ConsoleBox適切な使い方ガイド作成
- ✅ 4つのロギングカテゴリ確立user-facing/dev-debug/monitoring/internal Rust
- ✅ 3つのロギングBoxパターン設計Lightweight/Structured/Contextual
- ✅ hako_logging_design.md 作成、logging_policy.md 更新
- **スコープ**: .hako アプリケーション側のロギングベストプラクティス確立
feat(Ring0): Phase 107 - Ring0.FsApi FileIo integration complete Implementation Summary: Phase 107 establishes FileBox as a unified layer over Ring0.FsApi Completed Tasks: - Task 1: FsApi SSOT review and documentation - Task 2: FileIo designed as FsApi wrapper - Task 3: Ring0FsFileIo implementation added - Task 4: Fail-Fast integration verified - Task 5: Documentation integration complete Key Changes: 1. New File: src/providers/ring1/file/ring0_fs_fileio.rs - Ring0.FsApi-based FileIo implementation - Stateful wrapper (open/read/close) - UTF-8 handling via read_to_string() - One-file-at-a-time semantics (tested) 2. provider_lock.rs: - Added init_default_filebox_provider() - Auto-registration helper for Ring0FsFileIo 3. plugin_host.rs: - with_core_from_registry_optional() auto-registers default provider - Plugin priority maintained (debug logging) - Phase 106 MissingService check still active (Fail-Fast preserved) 4. Documentation: - phase107_fsapi_fileio_bridge.md: Complete design doc - phase106_filebox_design_revised.md: Phase 107 integration notes - core_boxes_design.md: Layer diagram and principles Design Decisions: - UTF-8 handling: read_to_string() for text-focused use cases - One file at a time: open() returns Err if already open - Plugin priority: init_default_filebox_provider() fails gracefully Test Results: - cargo build --release: SUCCESS - plugin_host tests: 11 passed - ring0_fs_fileio tests: 4 passed Next Steps (Phase 108+): - minimal/no-fs profile support - write operations - multi-file handle support
2025-12-03 18:16:49 +09:00
- **Phase 105: Logger Box Framework設計**2025-12-04
- ✅ Logger Box インターフェース設計(ログレベル: DEBUG/INFO/WARN/ERROR
- ✅ 3つの設計パターン文書化Lightweight/Structured/Contextual
- ✅ リファレンス実装例作成pseudo-code、実行テストは Phase 106+
- ✅ logger_box_design.md 作成500+ lines
- ✅ logging_policy.md / hako_logging_design.md / ring0-inventory.md にクロスリファレンス追加
- **スコープ**: 設計ドキュメントのみRust実装なし、Phase 106+で実装)
- **成果**: ConsoleBox基盤の構造化ロギングフレームワーク確立
feat(Ring0): Phase 107 - Ring0.FsApi FileIo integration complete Implementation Summary: Phase 107 establishes FileBox as a unified layer over Ring0.FsApi Completed Tasks: - Task 1: FsApi SSOT review and documentation - Task 2: FileIo designed as FsApi wrapper - Task 3: Ring0FsFileIo implementation added - Task 4: Fail-Fast integration verified - Task 5: Documentation integration complete Key Changes: 1. New File: src/providers/ring1/file/ring0_fs_fileio.rs - Ring0.FsApi-based FileIo implementation - Stateful wrapper (open/read/close) - UTF-8 handling via read_to_string() - One-file-at-a-time semantics (tested) 2. provider_lock.rs: - Added init_default_filebox_provider() - Auto-registration helper for Ring0FsFileIo 3. plugin_host.rs: - with_core_from_registry_optional() auto-registers default provider - Plugin priority maintained (debug logging) - Phase 106 MissingService check still active (Fail-Fast preserved) 4. Documentation: - phase107_fsapi_fileio_bridge.md: Complete design doc - phase106_filebox_design_revised.md: Phase 107 integration notes - core_boxes_design.md: Layer diagram and principles Design Decisions: - UTF-8 handling: read_to_string() for text-focused use cases - One file at a time: open() returns Err if already open - Plugin priority: init_default_filebox_provider() fails gracefully Test Results: - cargo build --release: SUCCESS - plugin_host tests: 11 passed - ring0_fs_fileio tests: 4 passed Next Steps (Phase 108+): - minimal/no-fs profile support - write operations - multi-file handle support
2025-12-03 18:16:49 +09:00
- **次のステップ**: Phase 106FileBox provider_lock & Fail-Fast、Phase 107FsApi 統合 or Logger 出力先拡張)
feat(box_factory): Phase 86 BoxFactory Priority normalization Phase 86: BoxFactory Priority 正常化プロジェクト完了 目的: - BoxFactory のデフォルトポリシーを BuiltinFirst から StrictPluginFirst に変更 - プラグイン版 StringBox/ArrayBox/MapBox が正常に使用できるよう正常化 - Phase 85 (Ring0/Ring1-Core 境界設計) の土台準備 実装内容: 1. ドキュメント作成 - docs/development/current/main/factory_priority.md: 完全仕様文書化 2. コード修正 (1行のみ) - UnifiedBoxRegistry::new() が with_env_policy() を使用 - デフォルトポリシーが StrictPluginFirst に変更 3. テスト追加 (5件, 全パス) - test_default_policy_is_strict_plugin_first: デフォルトポリシー確認 - test_env_policy_override: 環境変数制御確認 - test_reserved_type_protection: 予約型保護動作確認 - test_plugin_override_with_env: 予約型 override 確認 - test_non_reserved_plugin_priority: 非予約型プラグイン優先確認 効果: - ✅ プラグイン版 StringBox/ArrayBox/MapBox が正常に使用可能 - ✅ core_required Box の予約名保護維持 - ✅ 環境変数による柔軟な制御が可能 - ✅ テスト改善: 500→506 passed, 34→33 failed (+6 passed, -1 failed) core_required Box リスト (暫定): - Core value types: StringBox, IntegerBox, BoolBox, FloatBox, NullBox - Core containers: ArrayBox, MapBox, ResultBox - Core method indirection: MethodBox 環境変数: - NYASH_BOX_FACTORY_POLICY: ポリシー選択 (default: strict_plugin_first) - NYASH_USE_PLUGIN_BUILTINS: core_required override 許可 - NYASH_PLUGIN_OVERRIDE_TYPES: 個別 Box override 許可 Phase 85 準備: - Ring0/Ring1-Core 境界設計の土台が整った - ConsoleBox の扱いは Phase 85 で最終決定 完了条件: - ✅ factory_priority.md 作成完了 - ✅ UnifiedBoxRegistry::new() 修正完了 - ✅ デフォルトポリシー StrictPluginFirst 確定 - ✅ テスト 5件追加・全パス - ✅ CURRENT_TASK.md 更新完了 - ✅ Phase 85 README 準備完了 参考: - 設計文書: docs/development/current/main/factory_priority.md - Phase 85 計画: docs/private/roadmap2/phases/phase-85-ring0-runtime/README.md 🎉 Phase 86 完了!次は Phase 85 で Ring0/Ring1-Core 境界の文書化へ
2025-12-02 21:52:18 +09:00
12. **Phase 86: BoxFactory Priority 正常化****完了**2025-12-02
- **目的**: BoxFactory のデフォルトポリシーを `BuiltinFirst` から `StrictPluginFirst` に変更し、プラグイン版 Box が正常に使用できるよう正常化。
- **実装内容**:
- ✅ 現状仕様の文書化(`docs/development/current/main/factory_priority.md`
-`UnifiedBoxRegistry::new()` を 1 行修正(`with_policy(BuiltinFirst)``with_env_policy()`
- ✅ テスト 5 件追加・全パスdefault policy / env override / reserved protection / plugin override / non-reserved priority
- ✅ Phase 85 README 準備完了(`docs/private/roadmap2/phases/phase-85-ring0-runtime/README.md`
- **効果**:
- プラグイン版 StringBox/ArrayBox/MapBox が正常に使用可能に
- core_required BoxStringBox/IntegerBox/BoolBox/ArrayBox/MapBox 等)の予約名保護維持
- 環境変数 `NYASH_BOX_FACTORY_POLICY` による柔軟な制御が可能
- テスト改善500 passed, 34 failed → 506 passed, 33 failed+6 passed, -1 failed
- **詳細**: [factory_priority.md](docs/development/current/main/factory_priority.md)
### バックログ
#### ロギングフレームワーク拡張Phase 106+
- **Phase 106: Logger Box 出力リダイレクト**
- Logger Box から FileBox へのログ出力機能実装
- Logger Box から NetworkBox へのリモートログ送信機能実装
- Phase 105 で設計した interface 互換性維持
- **Phase 107: アプリケーション移行**
- hako_check を Logger Box 使用に移行
- selfhost-compiler を Logger Box 使用に移行
- Nyash ツール全体のロギング標準化
- **Phase 108+: 高度ロギング機能**
- 構造化ロギングJSON format
- ログアグリゲーション
- パフォーマンスメトリクス
#### その他
- StageB/selfhost smokes の扱い整理Phase 30.1 フォロー)
- quick プロファイルで `stage1_launcher_*` / `phase251*` 系が Stage3 デフォルト環境で不安定。今後、quick では SKIP にするか、StageB emit 抽出ロジックを安定化するかを決める。
- `MirFunction.blocks: HashMap``BTreeMap` で非決定的テスト解消
- Phase 25.1 同様のパターン適用
- selfhost StageB 子プロセスへのソース渡し経路の簡素化(`--source "$SRC_CONTENT"` で argv を肥大化させず、HAKO_SRC 環境変数や一時ファイル経由に統一する設計を将来フェーズで検討)。
- Phase 71-SSA: StageB / selfhost ラインは「SSA デバッグ用の観測窓」として切り出し、
代表パスselfhost_build + stage1_run_min.hakoが JSON v0 emit まで通るかどうかを別フェーズで追う。
詳細: `docs/private/roadmap2/phases/phase-71-ssa-debug/README.md`
- Phase 81-JoinIR-Strict: JoinIR を「if/loop/PHI の真」として扱い、
JoinIR 対象関数では `if_phi` / `LoopBuilder` / 旧 MIR Builder にフォールバックしない Strict モードを導入する。
代表 If/Loopmir_joinir_if_select / mir_stage1_staticcompiler_receiver / mir_joinir_stage1_using_resolver_min
`NYASH_JOINIR_CORE=1 NYASH_JOINIR_STRICT=1` で全て green を確認済みStrict で lowering 失敗なし)。
代表パスskip_ws / trim / resolve / print_tokens / filter / read_quoted / Stage1/StageB 代表)では、
JoinIR lowering / VM ブリッジ失敗を即エラー扱いとし、レガシー経路は「未対応関数専用」に縮退させる。
docs(phi_core): Phase 70 完全達成!Trio 完全削除 (~1,443行) ## Phase 70 実装完了 ### ✅ 完了タスク(6/6) **70-1**: loop_form_intake.rs Trio 使用削除 - 29行 → 2行(27行削減、85%削減) - LocalScopeInspectorBox / LoopVarClassBox imports 削除 - 二重分類問題解消(LoopScopeShape が SSOT) **70-2**: loop_to_join.rs 呼び出し側修正 - var_classes 引数削除 - Trio 依存ゼロ達成 **70-3**: 中間テスト - loopform 14/14 PASS ✅ - 退行なし確認 **70-4**: phi_core/mod.rs 公開面削除(ユーザー実施) - pub mod 3箇所削除 **70-5**: Trio 本体3ファイル削除(ユーザー実施) - loop_var_classifier.rs: 578行 - loop_exit_liveness.rs: 414行 - local_scope_inspector.rs: 361行 **70-6**: 最終テスト・ドキュメント - 498 passed, loopform 全 PASS ✅ - Phase 70 完了記録追加 ### 📊 削減実績 **合計削減**: **~1,443行**(Phase 69-4 見込み通り) **ファイル別**: - Trio 定義3ファイル: 1,353行削除 - loop_form_intake.rs: 27行削減 - phi_core/mod.rs: pub mod 3箇所削除 ### 🎯 達成内容 **1. 二重分類問題解消** ✅ - Before: intake_loop_form() + LoopScopeShape で2回分類 - After: LoopScopeShape のみで1回分類(SSOT 確立) **2. Trio 依存完全排除** ✅ - 外部依存: 2箇所 → 0箇所 - Trio 本体: 完全削除 **3. LoopScopeShape SSOT 確立** ✅ - 変数分類: LoopScopeShape.pinned / carriers - Exit liveness: LoopScopeShape.exit_live - 定義追跡: LoopScopeShape.variable_definitions ### 🎊 Phase 48-6 設計の完全達成 **Phase 48-6 目標**: Trio を builder.rs のみに封じ込める **Phase 70 達成**: Trio 完全削除(封じ込めから削除への昇華) **進化の完結**: 1. Phase 25.1: Option C 実装(Trio 誕生) 2. Phase 48-4: LoopScopeShape 実装(Trio 代替) 3. Phase 48-6: Trio を builder.rs に封じ込め 4. Phase 69-3: MIR 決定性修正(BTreeSet 化) 5. Phase 69-4: Trio 削除準備完了 6. **Phase 70: Trio 完全削除** 🎉 ### 🧪 テスト結果 - loopform: 14/14 PASS ✅ - 全体: 498 passed; 43 failed(既知エラーのみ、新規エラーなし) ### 📝 変更ファイル **削除**: - src/mir/phi_core/loop_var_classifier.rs (578行) - src/mir/phi_core/loop_exit_liveness.rs (414行) - src/mir/phi_core/local_scope_inspector.rs (361行) **修正**: - src/mir/join_ir/lowering/loop_form_intake.rs - src/mir/join_ir/lowering/loop_to_join.rs - src/mir/phi_core/mod.rs **ドキュメント**: - docs/development/current/main/phase69-4-trio-deletion-plan.md ### 🚀 Phase 69-70 合計削減 **~1,485行削減**: - Phase 69-2: 42行(inspector 引数削除) - Phase 70: 1,443行(Trio 完全削除) 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-02 09:45:54 +09:00
- Phase 82-if-phi-retire予定: P3-C ジェネリック型推論ラインを拡張し、
`lifecycle.rs` から `infer_type_from_phi*` 呼び出しを完全に排除するP3-C まで GenericTypeResolver で食い切る)。
あわせて `collect_assigned_vars_via_joinir` を JoinIR/AST 側の分析モジュールに移動し、
`phi_core::if_phi` への実コードからの参照をゼロにした上で `if_phi.rs` 本体を削除する(歴史メモは docs 側にのみ保持)。
- Phase 74-SSA-static-delegation将来フェーズ候補: Phase 71-SSA で判明した「static box 委譲時に ValueId マッピングが壊れる」
Rust MIR ビルダー側の根本バグを正式に修正するライン。
現 HEAD では `.hako` 層で ParserBox → ParserStringUtilsBox などの委譲を外すことで SSA undef は 13件→0件に根治しており、
最小 .hako ではバグを再現できないため、MIR Builder の修正は **再現用テストを用意できる将来フェーズに委譲**する。
当面は「box→static box への薄い委譲メソッドを増やさない」というコーディング規約で安全運用し、
Phase 74 では commit 13ce9e68 以前の形を元にした再現用テストMIR Builder 修正+委譲パターンの復活をまとめて扱う。
---
## 3. 旧フェーズ(過去ログへのポインタ)
古いフェーズの詳細な経緯やログは、以下のドキュメントと
`docs/private/roadmap2/CURRENT_TASK_2025-11-29_full.md` を見てね。
- Phase 21.7 — Static Box Methodization
- StaticMethodId / NamingBox で BoxName.method/arity 名前解決の SSOT 化。
- docs: `docs/development/current/main/phase-21.7-naming-ssot-checklist.md` など。
- Phase 25.x / 26.x — LoopForm v2 / LoopSSA v2 / Exit PHI / ExitLiveness
- LoopForm v2 / LoopSSA v2 の整備と Exit PHI / ExitLiveness まわりの 4 箱構成。
- Phase 2732 — JoinIR 初期実験〜汎用化
- LoopToJoinLowerer / LoopScopeShape / JoinIR VM Bridge を minimal ケースから Stage1 / StageB へ広げていくライン。
- docs: `docs/private/roadmap2/phases/phase-27-joinir*`, `phase-31-looptojoin-lowerer`, `phase-32-joinir-complete-migration` など。
CURRENT_TASK.md 自体は「いまどこを触っているか」と「次に何をやるか」を
1 画面で把握できる軽さを維持する方針だよ。***