Files
hakorune/docs/reference/runtime/kernel-and-plugins.md

53 lines
3.1 KiB
Markdown
Raw Permalink Normal View History

# NyKernel と Plugins — 最小ランタイムとプラグイン体系Phase 15.5
Status: Proposed (受け口のみ; 既定OFF)
ADR: docs/development/adr/adr-001-no-corebox-everything-is-plugin.md
## 目的
- Kernel を最小化(箱を持たない)し、機能はすべて Plugin で提供する。
- VM/LLVM 双方から同一 ABI`ny_new_box` / `ny_call_method`)で箱を扱う。
## 起動シーケンス(標準形)
1) NyKernel initGC/Handle/TLV/Extern/PluginRegistry
2) nyash.toml 読み込み
- `plugins.bootstrap`(静的束)を登録
- `plugins.dynamic`.so/.dllがあれば dlopen 登録
3) Plugin Verify必須メソッド/TLV/ABI
4) 実行VM/LLVM → `ny_call_method`
ブートの不変条件(重要)
- Provider Lock型→提供者の対応表が確定するまで、いかなる Box 生成も禁止。
- Kernel ログ(生バイト)で初期エラーを出力し、`StringBox` 等の Box をログ用途に使わない。
- Verify に失敗した場合は、Kernel ログで理由を表示して即終了する。
## Provider/Type 分離(概要)
- Stable Type NameSTN: `StringBox`, `IntegerBox` など。コード上の型名は不変。
- Provider IDPVN: `kernel:string@1.0` / `acme:string@2.1` など実装提供者。
- TOML で STN→PVN をバインドし、置換は TOML 側で行う。
Provider Lockロック
- 起動時に `types.<Type>` の provider を決定し、Provider Lock を作成・固定する。
- Lock 前の `ny_new_box` / `ny_call_method` はエラーE_PROVIDER_NOT_LOCKED
- Handle は `{ type_id, provider_id }` を保持し、デバッグビルドでは不一致検知時に panic本番では混入しない設計
## ポリシー(例)
- `plugin-first`(デフォルト): 動的プラグインの上書きを許可
- `compat_plugin_first`: 静的→動的のフォールバックを許可(移行期)
- `static_only`(本番): 静的のみ許可
Interop同一型の異 Provider 混在)
- 既定は混在禁止forbid。同一プロセス内で 1 Type = 1 Provider を維持する。
- 研究・開発用途でのみ `explicit/auto` を許可できるが、本番非推奨。
- explicit: 明示 API による変換のみ許可UTF8 などの正規形式を介する)
- auto: 暗黙変換を許可し、変換回数・バイト数をメトリクスに集計(本番非推奨)
## 現状の段階
- 受け口/ドキュメントの整備を先行(挙動は不変)。
- using は SSOT+AST に移行済みprod は file-using 禁止)。
- VM fallback の個別救済は暫定(短期で Bootstrap Pack へ移行し撤去)。
- VM fallbackMIR interpreterの役割は「軽量デバッグ実行器」フロントエンドParser/Using/AST→MIRの健全性をすばやく確認するために維持。機能は最小限に留め、プラグイン/本流VM/LLVM の実装が主となる(本番・性能評価には使用しない)。
関連ドキュメント
- nyash.toml のスキーマと例: docs/reference/config/nyash-toml.md
- usingSSOT/AST/Profiles: docs/reference/language/using.md