Files
hakorune/docs/development/roadmap/phases/phase-10.1/README.md
Moe Charm 6fdc52457e Phase番号再編成: プラグインBox統一化を10.1に昇格
- 革新的発見: 既存プラグインシステム(C ABI)でJIT→EXE実現可能
- Phase 10.1: プラグインBox統一化(新規)
- Phase 10.5: Python統合(旧10.1を移動)
- CURRENT_TASKを更新して新計画を反映

Everything is Box → Everything is Plugin への進化
2025-08-29 03:32:50 +09:00

2.9 KiB
Raw Blame History

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"