- Create 3-stage pipeline architecture to solve borrow checker conflicts - Stage 1 (ScanBox): Read-only scanning, identify rewrites (170 lines) - Stage 2 (PlanBox): Pure transformation, generate new blocks (85 lines) - Stage 3 (ApplyBox): Builder mutation only (75 lines) New Files: - scan_box.rs: Stage 1 - Read-only scan for RewritePlan - plan_box.rs: Stage 2 - Transform RewritePlan → RewrittenBlocks - apply_box.rs: Stage 3 - Apply RewrittenBlocks to MirBuilder - C-2.1-pipeline-refactoring.md: Implementation guide Data Structures: - RewritePlan: Describes WHAT to rewrite (tail calls, returns, PHI, params) - RewrittenBlocks: Contains HOW to rewrite (new blocks, replacements, inputs) Benefits: - Borrow checker safety: No overlapping mutable/immutable borrows - Single responsibility: Each stage has one clear purpose - Testability: Each stage can be unit tested independently - Maintainability: Clear data flow, isolated changes Status: - Scaffolding: ✅ Complete (structure defined, stub implementations) - Integration: ⏳ Next step (refactor merge_and_rewrite to use 3 stages) Build: cargo build --release ✅ 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
Nyash Development Documentation 🔧
開発者向けの進行中タスクと開発計画ドキュメントです。
📂 ディレクトリ構造
current/
CURRENT_TASK.md- 現在進行中のタスク- アクティブな開発作業の詳細
- 最新の実装状況
roadmap/
- phases/ - フェーズ別開発計画
- phase-8/ - AST→MIR変換
- phase-9/ - VM/JIT実装
- phase-10/ - AOT最適化
- native-plan/ - ネイティブビルド計画
- 実行バックエンド統合
- パフォーマンス目標
proposals/
- RFC(Request for Comments)
- 新機能提案
- 設計ディスカッション
🎯 重要な参照先
- 進行状況:
current/CURRENT_TASK.md - 開発計画:
roadmap/phases/ - 技術提案:
proposals/ - ドキュメントのステータス/入口ポリシー:
doc-status-policy.md - JoinIR / Selfhost の入口:
current/main/01-JoinIR-Selfhost-INDEX.md
📝 注意事項
このディレクトリの内容は開発中であり、頻繁に変更されます。
安定した仕様はreference/を参照してください。