- ChatGPT5からの的確なアドバイスを設計文書に反映 - nyrt_*(コアランタイム)とnyplug_*(プラグイン)の命名規則 - 実装ステップガイドの詳細化(VM→JIT→AOTの順序) - 最小限のC ABIヘッダ雛形を定義 '手順さえ守れば大丈夫' - 一歩ずつ確実に進める計画
Phase 10.1: JIT→EXE via Plugin Box Unification
🎯 革新的発見:すべてはプラグインになる
核心的洞察
既存のプラグインシステム(BID-FFI)がすでに完全なC ABIを持っている。 これを活用することで、JIT→EXE変換が現実的に可能。
📊 フェーズ概要
目標
- ビルトインBoxをプラグイン化してC ABI統一
- JITから統一されたプラグインAPIを呼び出し
- スタティックリンクによるスタンドアロンEXE生成
背景
現在の構造:
- JIT → HostCall → Rustビルトイン(複雑)
- JIT → PluginInvoke → プラグインBox(C FFI)
統一後:
- JIT → PluginInvoke → すべてのBox(統一!)
- EXE → PluginInvoke → スタティックリンクされたBox
🚀 実装計画
Week 1: ArrayBoxプラグイン化PoC
- ArrayBoxをプラグインとして再実装
- JITからのプラグイン呼び出しテスト
- パフォーマンス測定(HostCall vs Plugin)
Week 2: 主要Box移行
- StringBox、IntegerBox、BoolBoxのプラグイン化
- JIT lowering層の統一(plugin_invoke経由)
- 既存HostCallとの共存メカニズム
Week 3: 静的リンク基盤
- プラグインの
.aライブラリビルド - 最小ランタイム(nyash-runtime)設計
- リンカースクリプト作成
Week 4: EXE生成実証
- Hello Worldレベルのスタンドアロン実行
- Linux/macOSでの動作確認
- デバッグ情報とunwind対応
📁 ディレクトリ構造(予定)
plugins/
├── nyash-core-boxes/ # ビルトインBox群
│ ├── nyash-array-plugin/
│ ├── nyash-string-plugin/
│ └── nyash-integer-plugin/
├── nyash-runtime-minimal/ # 最小ランタイム
└── existing/ # 既存プラグイン
├── nyash-file-plugin/
└── nyash-net-plugin/
🔗 関連資料
⚡ 成功指標
-
技術的検証
- ArrayBoxがプラグインとして動作
- JITからの呼び出し成功
- 性能劣化10%以内
-
統合達成
- 5つ以上のビルトインBoxがプラグイン化
- JIT lowering層の完全統一
-
EXE生成
- スタンドアロン実行ファイル生成
- 基本的なNyashプログラムの動作
🎉 期待される成果
- Everything is Plugin - 新たな設計哲学の確立
- 自己ホスティングへの現実的な道筋
- プラグインエコシステムの拡大可能性
"Everything is Box → Everything is Plugin → Everything is Possible"