🎉 Conservative PHI Box理論による完全SSA構築 **Phase 7-B: Conservative PHI実装** - 片方branchのみ定義変数に対応(emit_void使用) - 全変数にPHI生成(Conservative Box理論) - Stage-1 resolver全テスト緑化(3/3 PASS) **Phase 25.1f: ControlForm観測レイヤー** - LoopShape/IfShape/ControlForm構造定義 - Loop/If統一インターフェース実装 - debug_dump/debug_validate機能追加 - NYASH_CONTROL_FORM_TRACE環境変数対応 **主な変更**: - src/mir/builder/phi.rs: Conservative PHI実装 - src/mir/control_form.rs: ControlForm構造(NEW) - src/mir/loop_builder.rs: LoopForm v2デフォルト化 **テスト結果**: ✅ mir_stage1_using_resolver_min_fragment_verifies ✅ mir_stage1_using_resolver_full_collect_entries_verifies ✅ mir_parserbox_parse_program2_harness_parses_minimal_source 🤖 Generated with Claude Code Co-Authored-By: Claude <noreply@anthropic.com> Co-Authored-By: ChatGPT <chatgpt@openai.com>
rewrite — Known 経路の関数化 + 特殊規則(P1)
目的
- Known 受け手のメソッド呼び出し
obj.m(a)を関数呼び出しClass.m(me,obj,a)に正規化し、実行系を単純化する。 - 表示系の特殊規則(
toString/stringify→ 規範str)を一箇所に集約する(互換維持)。 - 仕様は不変。Union は観測のみで、Known のみ関数化対象。
責務
- known.rs: Known 経路の instance→function 正規化(ユーザー Box のみ、既存ガード尊重)。
- special.rs:
toString/stringify→strの早期処理(Class.str/0 を優先、互換で stringify/0)。equals/1もここに集約(Known 優先 → 一意候補のみ許容)。
- 観測は observe 層に委譲(resolve.choose など)。
非責務(禁止)
- Union の強引な関数化(Unknown/曖昧なものは扱わない)。
- 起源付与/型推論の実施(origin 層に限定)。
- NYABI 呼び出しや VM 直接呼び出し。
API(呼び出し側から)
try_known_rewrite(builder, recv, class, method, args) -> Option<Result<ValueId,String>>try_unique_suffix_rewrite(builder, recv, method, args) -> Option<Result<ValueId,String>>try_known_or_unique(builder, recv, class_opt, method, args) -> Option<Result<ValueId,String>>try_early_str_like(builder, recv, class_opt, method, arity) -> Option<Result<ValueId,String>>try_special_equals(builder, recv, class_opt, method, args) -> Option<Result<ValueId,String>>
レイヤールール
- Allowed: Builder のメタ参照/関数名生成、MirInstruction の生成(関数化結果)。
- Forbidden: origin/observe のロジックを混在させない(必要時は呼び出しで連携)。
決定原則
- Known のみ関数化(
value_origin_newboxが根拠)。 - 表示系は規範
strを優先、stringifyは当面互換として許容。 - すべての決定は dev 観測(resolve.try/choose)で可視化し、挙動は不変。