✨ Phase 3.1-3.2実装完了 - build_indirect_call_expressionでCallTarget::Value使用 - print関数をcall_global print()として統一 - build_function_callでemit_unified_call使用 - ExternCall(env.console.log)→Callee::Global(print)完全移行 🏗️ MIR統一基盤構築 - src/mir/definitions/call_unified.rs: 統一定義(297行) - emit_unified_call()と便利メソッド3種実装 - NYASH_MIR_UNIFIED_CALL=1で段階移行制御 - VM実行器でCallee対応実装済み 📊 進捗状況(26%削減見込み) - Phase 1-2: ✅ 基盤構築完了 - Phase 3.1-3.2: ✅ 基本関数統一完了 - Phase 3.3: 🔄 BoxCall統一中 - Phase 4: 📅 Python LLVM(最優先・63%削減) - Phase 5: 📅 PyVM/VM統一 📚 ドキュメント更新 - CLAUDE.md: テストスクリプト参考集追加 - CURRENT_TASK.md: Phase 3進捗更新 - python-llvm-priority-rationale.md: 優先順位戦略文書化 - mir-call-unification-master-plan.md: スケジュール最新化 🎯 6種類→1種類: Call/BoxCall/PluginInvoke/ExternCall/NewBox/NewClosure → MirCall統一へ 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
4.1 KiB
4.1 KiB
Python LLVM優先実装の戦略的根拠
作成日: 2025-09-24
🎯 なぜPython LLVMを優先するか
1. 最大のコード削減効果
| 実行器 | 現在行数 | 削減後 | 削減率 | 優先度 |
|---|---|---|---|---|
| Python LLVM | 804行 | 300行 | 63% | 1位 |
| PyVM/VM | 712行 | 512行 | 28% | 2位 |
| mini-vm | 新規 | - | - | 3位 |
2. 実装の独立性
Python LLVMの利点:
- 独立したPythonスクリプト - Rustビルドと無関係
- 即座にテスト可能 -
python llvm_builder.pyで実行 - ロールバック容易 - 環境変数で旧実装に切り替え可能
# 環境変数による段階移行
if os.environ.get('NYASH_MIR_UNIFIED_CALL') == '1':
return dispatch_unified_call(inst) # 新実装
else:
return dispatch_legacy(inst) # 旧実装
3. 技術的シンプルさ
現在の問題(6種類の処理):
# src/llvm_py/llvm_builder.py の現状
if inst['op'] == 'Call':
handle_call(...)
elif inst['op'] == 'BoxCall':
handle_box_call(...)
elif inst['op'] == 'PluginInvoke':
handle_plugin_invoke(...)
elif inst['op'] == 'ExternCall':
handle_extern_call(...)
elif inst['op'] == 'NewBox':
handle_new_box(...)
elif inst['op'] == 'NewClosure':
handle_new_closure(...)
統一後(1つの処理):
# 統一後のシンプルな実装
if inst['op'] == 'MirCall':
callee = inst['callee']
if callee['type'] == 'Global':
emit_global_call(callee['name'], inst['args'])
elif callee['type'] == 'Method':
emit_method_call(callee['receiver'], callee['method'], inst['args'])
elif callee['type'] == 'Constructor':
emit_constructor(callee['box_type'], inst['args'])
# ... 統一された処理
📊 PyVM/VMを後にする理由
1. 依存関係の観点
- MIR構造の統一完了後が望ましい
- Python LLVM実装での知見を活用可能
- 相互検証(LLVM vs VM)が可能に
2. リスク管理
- VMは実行器の中核なので慎重に
- Python LLVMで先に検証してから適用
3. 削減効果は中程度
- 28%削減は重要だが、63%には及ばない
- 優先順位として2位が妥当
📅 推奨実装スケジュール
gantt
title MIR Call統一実装スケジュール
dateFormat YYYY-MM-DD
section Phase 3(MIR Builder)
Phase 3.1-3.2 完了 :done, 2025-09-23, 1d
Phase 3.3 BoxCall統一 :active, 2025-09-24, 2d
section Phase 4(Python LLVM)
Phase 4.1 dispatch統一 :2025-09-26, 3d
Phase 4.2 処理実装 :2025-09-29, 4d
section Phase 5(VM/PyVM)
Phase 5 VM統一 :2025-10-03, 5d
section Phase 6(mini-vm)
Phase 6 新規実装 :2025-10-08, 5d
🎯 期待される成果
短期的成果(2週間)
- コード削減: 1,904行削減(26%)
- 保守性向上: 6種類→1種類の処理パターン
- 理解容易性: 統一されたCall semantics
長期的成果(1ヶ月)
- Phase 15への貢献: 全体目標の7%達成
- セルフホスティング基盤: mini-vm統一実装
- 将来の拡張性: 新Call種別追加が容易に
🚀 アクションプラン
今週(Phase 3完了)
- emit_box_or_plugin_call統一化
- テストケース準備
- Python LLVM実装調査
来週(Phase 4: Python LLVM)
- llvm_builder.py リファクタリング開始
- dispatch_unified_call実装
- 環境変数による段階移行
- ベンチマーク測定
再来週(Phase 5: VM/PyVM)
- mir_interpreter.rs統一
- pyvm/vm.py統一
- 相互検証テスト
- パフォーマンス最適化
まとめ
Python LLVM優先の判断は正しい:
- 最大効果 - 63%削減は圧倒的
- 低リスク - 独立実装で影響範囲限定
- 高速検証 - Pythonで即座にテスト可能
- 知見獲得 - 後続実装への学習効果
この戦略により、2週間で主要実行器の統一完了が現実的に達成可能。