Files
hakorune/docs/development/roadmap/phases/phase-10.1
Moe Charm 3a576a665c Phase 10.1: ChatGPT5のC ABI統一設計を文書化
- ChatGPT5からの的確なアドバイスを設計文書に反映
- nyrt_*(コアランタイム)とnyplug_*(プラグイン)の命名規則
- 実装ステップガイドの詳細化(VM→JIT→AOTの順序)
- 最小限のC ABIヘッダ雛形を定義

'手順さえ守れば大丈夫' - 一歩ずつ確実に進める計画
2025-08-29 03:42:59 +09:00
..

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 → プラグインBoxC 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/

🔗 関連資料

成功指標

  1. 技術的検証

    • ArrayBoxがプラグインとして動作
    • JITからの呼び出し成功
    • 性能劣化10%以内
  2. 統合達成

    • 5つ以上のビルトインBoxがプラグイン化
    • JIT lowering層の完全統一
  3. EXE生成

    • スタンドアロン実行ファイル生成
    • 基本的なNyashプログラムの動作

🎉 期待される成果

  • Everything is Plugin - 新たな設計哲学の確立
  • 自己ホスティングへの現実的な道筋
  • プラグインエコシステムの拡大可能性

"Everything is Box → Everything is Plugin → Everything is Possible"