feat: MIR Call命令統一Phase 3.1-3.2完了!統一Call実装進行中
✨ 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>
This commit is contained in:
96
docs/reference/mir/MIR14-SPECIFICATION.md
Normal file
96
docs/reference/mir/MIR14-SPECIFICATION.md
Normal file
@ -0,0 +1,96 @@
|
||||
# MIR14 命令セット仕様(2025-09-23現在)
|
||||
|
||||
## 📊 MIR14とは
|
||||
|
||||
**MIR14 = Core-13 + UnaryOp**
|
||||
|
||||
27命令→13命令→14命令という実践的な進化を経て、現在14命令で全実行形態をサポート。
|
||||
|
||||
## 🎯 Core-14命令
|
||||
|
||||
### 基本演算(5命令)
|
||||
1. **Const** - 定数ロード
|
||||
2. **BinOp** - 二項演算(+,-,*,/,%,&,|,^,<<,>>)
|
||||
3. **UnaryOp** - 単項演算(-,!,~)← 14番目の命令
|
||||
4. **Compare** - 比較演算(==,!=,<,<=,>,>=)
|
||||
5. **TypeOp** - 型操作(check/cast)
|
||||
|
||||
### メモリ(2命令)
|
||||
6. **Load** - メモリ読み込み
|
||||
7. **Store** - メモリ書き込み
|
||||
|
||||
### 制御(4命令)
|
||||
8. **Branch** - 条件分岐
|
||||
9. **Jump** - 無条件ジャンプ
|
||||
10. **Return** - 関数リターン
|
||||
11. **Phi** - SSA合流
|
||||
|
||||
### Box(2命令)
|
||||
12. **NewBox** - Box生成
|
||||
13. **BoxCall** - Boxメソッド呼び出し
|
||||
|
||||
### 外部(1命令)
|
||||
14. **ExternCall** - 外部関数呼び出し
|
||||
|
||||
## ❌ Core-14に含まれない命令
|
||||
|
||||
### Call系拡張(統合予定)
|
||||
- **Call** - 関数呼び出し(Callee型で拡張中)
|
||||
- **PluginInvoke** - プラグイン呼び出し(BoxCallと統合予定)
|
||||
- **NewClosure** - クロージャ生成
|
||||
|
||||
### レガシー命令(段階的削除)
|
||||
- **Print** - ExternCallに統合
|
||||
- **Debug** - ExternCallに統合
|
||||
- **Copy** - 最適化パス用
|
||||
- **Nop** - 何もしない
|
||||
|
||||
### 高度な機能(オプション)
|
||||
- **ArrayGet/ArraySet** - 配列操作
|
||||
- **RefGet/RefSet/RefNew** - 参照操作
|
||||
- **WeakRef/Barrier** - GC関連
|
||||
- **FutureNew/FutureSet/Await** - 非同期
|
||||
- **Throw/Catch/Safepoint** - 例外処理
|
||||
|
||||
## 📈 命令数の変遷
|
||||
|
||||
```
|
||||
初期(27命令): なんでも入れた状態
|
||||
↓
|
||||
MIR13(13命令): 極限まで削減
|
||||
↓
|
||||
MIR14(14命令): UnaryOp追加で実用的に ← 現在
|
||||
↓
|
||||
将来: Call統一でさらにシンプルに?
|
||||
```
|
||||
|
||||
## 🎯 設計原則
|
||||
|
||||
1. **最小限主義**: 本当に必要な命令だけ
|
||||
2. **Box中心**: すべてはBoxCallで表現
|
||||
3. **段階的拡張**: Core-14を基盤に、必要に応じて拡張
|
||||
|
||||
## 📊 実行形態別サポート
|
||||
|
||||
| 命令 | Interpreter | VM | JIT | AOT | 備考 |
|
||||
|------|------------|----|----|-----|------|
|
||||
| Core-14 | ✅ | ✅ | ✅ | ✅ | 完全サポート |
|
||||
| Call系 | ✅ | ✅ | △ | △ | 統合中 |
|
||||
| レガシー | ✅ | ✅ | × | × | 削除予定 |
|
||||
| 高度機能 | △ | △ | × | × | オプション |
|
||||
|
||||
## 🚀 今後の方向性
|
||||
|
||||
### Phase 15.5(現在)
|
||||
- Call系6命令を1つに統一(ChatGPT5 Pro A++案)
|
||||
- MirCall + Calleeで表現力向上
|
||||
|
||||
### 将来
|
||||
- Core-14 + MirCallで完全体へ
|
||||
- レガシー命令の完全削除
|
||||
- 高度機能の選択的サポート
|
||||
|
||||
## 📝 参考文献
|
||||
- [論文A: MIR14で作る万能実行系](docs/private/papers/paper-a-mir13-ir-design/)
|
||||
- [Call命令現状](docs/reference/mir/call-instructions-current.md)
|
||||
- [MIR命令実装](src/mir/instruction.rs)
|
||||
127
docs/reference/mir/call-instructions-current.md
Normal file
127
docs/reference/mir/call-instructions-current.md
Normal file
@ -0,0 +1,127 @@
|
||||
# MIR Call系命令の現状(2025-09-23)
|
||||
|
||||
## 📊 現在のCall系命令(6種類)
|
||||
|
||||
### 1. Call(関数呼び出し)
|
||||
```rust
|
||||
Call {
|
||||
dst: Option<ValueId>,
|
||||
func: ValueId, // 関数オブジェクト(ValueId)
|
||||
callee: Option<Callee>, // ← 今日追加した型安全解決
|
||||
args: Vec<ValueId>,
|
||||
effects: EffectMask,
|
||||
}
|
||||
```
|
||||
**用途**: 関数呼び出し全般(今日Callee型追加でシャドウイング対策)
|
||||
|
||||
### 2. BoxCall(Boxメソッド呼び出し)
|
||||
```rust
|
||||
BoxCall {
|
||||
dst: Option<ValueId>,
|
||||
box_val: ValueId, // レシーバー
|
||||
method: String, // メソッド名
|
||||
method_id: Option<u16>, // 統一レジストリID
|
||||
args: Vec<ValueId>,
|
||||
effects: EffectMask,
|
||||
}
|
||||
```
|
||||
**用途**: StringBox.concat()等、すべてのBoxメソッド
|
||||
|
||||
### 3. PluginInvoke(プラグイン強制)
|
||||
```rust
|
||||
PluginInvoke {
|
||||
dst: Option<ValueId>,
|
||||
box_val: ValueId,
|
||||
method: String,
|
||||
args: Vec<ValueId>,
|
||||
effects: EffectMask,
|
||||
}
|
||||
```
|
||||
**用途**: プラグインメソッド呼び出し(builtinフォールバックなし)
|
||||
|
||||
### 4. ExternCall(環境直結)
|
||||
```rust
|
||||
ExternCall {
|
||||
dst: Option<ValueId>,
|
||||
iface_name: String, // "env.console"
|
||||
method_name: String, // "log"
|
||||
args: Vec<ValueId>,
|
||||
effects: EffectMask,
|
||||
}
|
||||
```
|
||||
**用途**: env.console.log等、ホスト環境への直接呼び出し
|
||||
|
||||
### 5. NewBox(Box生成)
|
||||
```rust
|
||||
NewBox {
|
||||
dst: ValueId,
|
||||
box_type: String, // "StringBox"等
|
||||
args: Vec<ValueId>, // コンストラクタ引数
|
||||
}
|
||||
```
|
||||
**用途**: new StringBox("hello")等
|
||||
|
||||
### 6. NewClosure(クロージャ生成)
|
||||
```rust
|
||||
NewClosure {
|
||||
dst: ValueId,
|
||||
params: Vec<String>,
|
||||
body: Vec<MirInstruction>,
|
||||
captures: Vec<(String, ValueId)>,
|
||||
me: Option<ValueId>,
|
||||
}
|
||||
```
|
||||
**用途**: 関数リテラル、クロージャ
|
||||
|
||||
## 🔴 問題点
|
||||
|
||||
1. **重複**: CallとBoxCallの役割が重複
|
||||
2. **不統一**: PluginInvokeとBoxCallが分離
|
||||
3. **複雑**: 6種類のCall系命令は多すぎる
|
||||
4. **メンテ困難**: 各実行器(VM/JIT/LLVM)で6種類実装が必要
|
||||
|
||||
## ✅ Callee型(今日追加)
|
||||
|
||||
```rust
|
||||
pub enum Callee {
|
||||
Global(String), // print, error等
|
||||
Method { // Box.method()
|
||||
box_name: String,
|
||||
method: String,
|
||||
receiver: Option<ValueId>,
|
||||
},
|
||||
Value(ValueId), // 第一級関数
|
||||
Extern(String), // 外部関数
|
||||
}
|
||||
```
|
||||
|
||||
**現状**: Callのみ対応、他は未統合
|
||||
|
||||
## 📈 統計(ソースコード分析)
|
||||
|
||||
| 命令 | 使用箇所数 | 主な用途 |
|
||||
|------|-----------|----------|
|
||||
| Call | 多数 | 一般関数呼び出し |
|
||||
| BoxCall | 多数 | Boxメソッド全般 |
|
||||
| PluginInvoke | 少数 | プラグイン限定 |
|
||||
| ExternCall | 少数 | print正規化後 |
|
||||
| NewBox | 多数 | Box生成全般 |
|
||||
| FunctionNew | 少数 | クロージャ |
|
||||
|
||||
## 🎯 今後の方向性
|
||||
|
||||
### ChatGPT5 Pro提案(A++案)
|
||||
- すべてをCall + Calleeに統一
|
||||
- receiverをCalleeに含める
|
||||
- EffectMaskで安全性管理
|
||||
- 段階的移行で実装
|
||||
|
||||
### 移行優先順位
|
||||
1. ExternCall → Call + Callee::Extern
|
||||
2. BoxCall → Call + Callee::Method
|
||||
3. PluginInvoke → Call + Callee::Method(effects=Sandbox)
|
||||
4. NewBox → そのまま残す(or Call + Callee::Constructor検討)
|
||||
|
||||
## 📝 更新履歴
|
||||
- 2025-09-23: Callee型追加(ChatGPT5 Pro設計)
|
||||
- 2025-09-23: 本ドキュメント作成
|
||||
Reference in New Issue
Block a user