Phase 142-loopstmt P0: Statement-level normalization 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Haiku 4.5 <noreply@anthropic.com>
3.5 KiB
3.5 KiB
Self Current Task — Backlog (main)
Status: Active
Scope: 「次にやる候補」を短く列挙するメモ。現状は docs/development/current/main/10-Now.md を入口にする。
Related:
docs/development/current/main/10-Now.mddocs/development/current/main/DOCS_LAYOUT.md
直近(JoinIR/selfhost)
-
Phase 142-loopstmt P1(planned): LLVM EXE smoke を追加
- 前提(DONE): Phase 142-loopstmt P0(正規化単位を statement(loop 1個)へ寄せる)
- ねらい: VM で固定済みの fixture を LLVM EXE でも parity 固定する。
- 受け入れ条件:
- 既存 fixture をそのまま使う(新パターン追加をしない)
- out-of-scope は
Ok(None)でフォールバック(既定挙動不変) - Phase 130 の LLVM EXE gate が前提(未完なら SKIP を維持)
-
Phase 141 P2+(planned): Call/MethodCall(effects + typing を分離して段階投入)
- ねらい: pure/impure 境界を壊さずに、impure lowering を段階投入する。
- 前提(DONE):
- Phase 141 P1.5: known intrinsic allowlist + available_inputs 3-source merge + diagnostics
- 受け入れ条件:
- out-of-scope は
Ok(None)でフォールバック(既定挙動不変) - effects の順序付けは SSOT で固定してから解禁(by-name 増殖禁止)
- out-of-scope は
-
Phase 143-loopvocab(planned): “新パターン追加” ではなく “語彙追加” で吸収
- 対象:
loop(true){ if(cond) break/continue }を StepTree/ControlTree の語彙として表現し、同じ lowering に流す - 受け入れ条件:
- capability guard(Fail-Fast)でスコープ外を明確化
- fixture/smoke を 1 本ずつ小さく固定(VM + LLVM EXE parity)
- 対象:
-
real-app loop regression の横展開(VM + LLVM EXE)
- ねらい: 実コード由来ループを 1 本ずつ最小抽出して fixture/smoke で固定する(段階投入)。
- 現状: Phase 107(find_balanced_array/object / json_cur 由来)まで固定済み。
- 次候補: JsonLoader/JsonCur から 1 本ずつ(fixture + integration smoke)で増やす。
-
P5b “完全E2E”(escape skip の実ループを end-to-end で固定)
- 現状: Phase 94 で VM E2E まで固定済み。次は selfhost 実コード(
apps/selfhost-vm/json_loader.hako)へ横展開して回帰を減らす。 - 入口:
docs/development/current/main/phases/phase-94/README.md
- 現状: Phase 94 で VM E2E まで固定済み。次は selfhost 実コード(
-
制御の再帰合成(docs-only → dev-only段階投入)
- ねらい:
loop/ifネストの "構造" を SSOT(ControlTree/StepTree)で表せるようにする - 注意: canonicalizer は観測/構造SSOTまで(ValueId/PHI配線は Normalized 側へ)
- 現状: Phase 119–128(if-only Normalized: reads/inputs/unknown-read/partial-assign keep/merge)まで完了
- ✅ 完了: Phase 129-C(post-if を post_k continuation で表現)
- 入口:
docs/development/current/main/design/control-tree.md
- ねらい:
中期(ループ在庫の残り)
- P5(guard-bounded): 大型ループを “小粒度” に割ってから取り込む(分割 or 新契約)
- P6(nested loops): capability guard で Fail-Fast 維持しつつ、解禁時の契約を先に固定
ドキュメント運用
- 重複が出たら「設計 SSOT(design)」に集約し、Phaseログ(phases)は “何をやったか/検証したか” に限定する
- 調査ログ(investigations)は結論を SSOT に反映してから Historical 化する