- TypeBox ABI雛形: メソッドスロット管理システム追加 - Type Registry: Array/Map/StringBoxの基本メソッド定義 - Host API: C ABI逆呼び出しシステム実装 - Phase 12ドキュメント整理: 設計文書統合・アーカイブ化 - MIR Builder: クリーンアップと分離実装完了 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
2.3 KiB
2.3 KiB
Nyash ABI戦略議論まとめ (2025-09-01)
📋 概要
Phase 12のプラグインシステム実装において、C ABIとNyash ABIの選択について、AI先生方と深い技術議論を行いました。
🗂️ ドキュメント一覧
-
- Gemini先生の長期エコシステム視点
- ABI安定性の重要性
- 段階的進化戦略(C ABI → SDK → WASM)
-
- Codex先生の実装最適化視点
- C呼出規約×Nyash値表現の提案
- VM/JIT最適化の具体策
-
- なぜ正解が難しいのかの深い分析
- 時間軸のジレンマ
- 「正解がない」ことが答え
🎯 結論:BoxCall拡張による統合案
最終的な実装方針
// MIRレベル:BoxCallをちょっと拡張
MirInstruction::BoxCall {
receiver: Value,
method: String,
args: Vec<Value>,
abi_hint: Option<AbiType>, // ← これだけ追加
}
利点
- MIR命令数は15個のまま(美しさ維持)
- 既存コードは変更不要(後方互換)
- プラグインごとにABI選択可能(段階的移行)
- Everything is Box哲学の体現
実装計画
Week 1: 基盤整備
- PluginABI enum定義
- nyash.tomlのabi field追加
- NyashValue構造体作成
Week 2: VM統合
- プラグインローダー拡張
- VM実行時のABI分岐
- pack/unpack実装
Week 3: 検証
- 比較ベンチマーク
- ドキュメント作成
- 方向性判断
🔑 重要な洞察
-
両ABI共存が現実的
- C ABI:既存資産・高速・安定
- Nyash ABI:型安全・拡張性・将来性
-
適応的戦略の採用
- 3ヶ月ごとに測定・評価
- データに基づく進化
-
箱理論による差し替え可能性
- 実装を箱に切り出す
- いつでも戻せる安心感
📊 次のステップ
- このREADMEを起点に実装開始
- 最小限のプロトタイプ作成
- 性能・開発体験の比較データ収集
- Phase 12本実装への反映
「間に挟むだけ」が最も難しい設計判断だった。しかし、BoxCall拡張という自然な解決策にたどり着いた。