Files
hakorune/docs/development/roadmap/phases/phase-17-loopform-selfhost/SCHEDULE.md

45 lines
2.2 KiB
Markdown
Raw Normal View History

# Phase 17 — 開発予定表LoopForm SelfHosting & Polish
期間目安: 4週間総量は実アプリ進行に合わせて調整
Week 1 — LoopForm MVPwhile, break/continue無し
- 目標: whileループを“キャリアタプル”へ正規化するユーザーマクロを実装Nyash/PyVM
- 成果物:
- apps/macros/examples/loop_normalize_macro.nyashMVP
- ゴールデン: while基本/2変数キャリア/更新式の正規化
- スモーク: selfhost-preexpand で自動適用→PyVM/LLVMの一致
- 受け入れ基準:
- ループヘッダのPHIが先頭グループ化され、空PHIが存在しない
- 代表ケースでPyVM/LLVMの出力一致
Week 2 — break/continue 対応+キャリア自動抽出
- 目標: ループ内のbreak/continueを LoopForm の構造に沿って安全に配置。更新対象変数の集合からキャリア自動推定。
- 成果物:
- マクロ拡張: break/continue/ネストの最小対応
- ゴールデン: break/continue混在、未更新変数保持
- 受け入れ基準:
- 分岐経路の合流でキャリアが常にwelltyped
- 変数の外側スコープ値が期待通り
Week 3 — for/foreach限定設計ドキュメント深掘り
- 目標: for/foreach を while へ前処理→LoopFormへ正規化。
- 成果物:
- 追加パターン: for (init; cond; step) / foreach (x in xs)
- ドキュメント: loopform-design.md制約/限界/今後のMIR 4命令案
- 受け入れ基準:
- for/foreachの代表ケースで一致
Week 4 — Polishing & 実アプリ適用
- 目標: 実アプリ/自己ホストにLoopFormを適用して安定運用。
- 成果物:
- スモーク/ゴールデン拡充、CIゲート最小化fast/min
- ガイド更新guides/loopform.md
- 受け入れ基準:
- 実アプリの主要ユースケースが緑
リスク/対策
- 複雑なネスト/例外: MVPでは簡略try/finallyとの相互作用は先送り→ドキュメントに制約明記
- 性能: コンパイル時のみの変換負荷。実行性能はMIR/LLVMへ委譲→ベンチで観測
- 仕様逸脱: 凍結遵守。必要時は限定的なDocs変更で表現