2025-08-17 17:31:46 +09:00
|
|
|
|
# 🎯 現在のタスク (2025-08-17)
|
2025-08-17 12:27:12 +09:00
|
|
|
|
|
2025-08-17 17:31:46 +09:00
|
|
|
|
## 🚀 **現在進行中: Phase 9.75g-0 型定義ファースト BID-FFI実装**
|
2025-08-17 12:27:12 +09:00
|
|
|
|
|
2025-08-17 17:31:46 +09:00
|
|
|
|
**目的**: FFI ABI v0準拠のシンプルで動くプラグインシステム構築
|
|
|
|
|
|
**戦略**: 型定義は全部最初に、実装は段階的に(unimplemented!活用)
|
|
|
|
|
|
**期間**: 1週間(2025-08-17〜2025-08-24)
|
|
|
|
|
|
**詳細**:
|
2025-08-17 18:17:04 +09:00
|
|
|
|
- [phase_9_75g_0_chatgpt_enhanced_final.md](../予定/native-plan/issues/phase_9_75g_0_chatgpt_enhanced_final.md) ← **ChatGPT最終案採用!**
|
|
|
|
|
|
- [ffi-abi-specification.md](../説明書/reference/box-design/ffi-abi-specification.md) ← **BID-1仕様に更新完了!**
|
2025-08-17 12:27:12 +09:00
|
|
|
|
|
2025-08-17 18:53:34 +09:00
|
|
|
|
### ✅ **Day 1 完了!** (2025-08-17)
|
2025-08-17 18:17:04 +09:00
|
|
|
|
- ✅ ChatGPT先生の最終レビュー完了
|
|
|
|
|
|
- ✅ ffi-abi-specification.mdをBID-1 Enhanced Editionに更新
|
|
|
|
|
|
- ✅ Handle設計(type_id + instance_id)確定
|
|
|
|
|
|
- ✅ BID-1 TLVフォーマット仕様確定
|
|
|
|
|
|
- ✅ プラグインAPI(nyash_plugin_*)仕様確定
|
2025-08-17 18:33:19 +09:00
|
|
|
|
- ✅ **BID-1基盤実装完了!**
|
|
|
|
|
|
- src/bid/モジュール構造作成
|
|
|
|
|
|
- TLVエンコード/デコード実装
|
|
|
|
|
|
- エラーコード定義(BidError)
|
|
|
|
|
|
- 型システム(BidType, BidHandle)
|
|
|
|
|
|
- **テスト4/4合格!** 🎉
|
2025-08-17 18:17:04 +09:00
|
|
|
|
|
2025-08-17 19:02:51 +09:00
|
|
|
|
### ✅ **Day 2 完了!** (2025-08-17)
|
2025-08-17 18:53:34 +09:00
|
|
|
|
**目標**: メタデータAPI実装(ホスト統合・プラグイン情報管理)
|
|
|
|
|
|
|
2025-08-17 19:02:51 +09:00
|
|
|
|
**実装完了**:
|
|
|
|
|
|
- ✅ HostVtable: ホスト機能テーブル(alloc/free/wake/log)
|
|
|
|
|
|
- ✅ NyashPluginInfo: プラグイン情報構造体
|
|
|
|
|
|
- ✅ NyashMethodInfo: メソッド情報構造体
|
|
|
|
|
|
- ✅ C FFI関数シグネチャ定義
|
|
|
|
|
|
- ✅ プラグインライフサイクル管理
|
|
|
|
|
|
- ✅ **テスト7/7合格!** 🎉
|
2025-08-17 18:53:34 +09:00
|
|
|
|
|
2025-08-17 21:09:32 +09:00
|
|
|
|
### ✅ **Day 3 完了!** (2025-08-17)
|
2025-08-17 20:55:49 +09:00
|
|
|
|
**目標**: 既存Box統合(StringBox/IntegerBox/FutureBoxブリッジ)
|
|
|
|
|
|
|
2025-08-17 21:09:32 +09:00
|
|
|
|
**実装完了** (100%達成!):
|
2025-08-17 20:55:49 +09:00
|
|
|
|
- ✅ BID Box Bridge設計: 既存Box型とBIDハンドルの相互変換インターフェース
|
|
|
|
|
|
- ✅ StringBox BIDブリッジ: Handle/TLV変換実装
|
|
|
|
|
|
- ✅ IntegerBox BIDブリッジ: Handle/TLV変換実装
|
2025-08-17 21:09:32 +09:00
|
|
|
|
- ✅ FutureBox BIDブリッジ: 非同期Box型の統合完了
|
2025-08-17 20:55:49 +09:00
|
|
|
|
- ✅ BoxRegistry: Box型とハンドルの管理システム
|
2025-08-17 21:09:32 +09:00
|
|
|
|
- ✅ 統合テスト: 全Box型ラウンドトリップテスト(4/4合格!)
|
2025-08-17 20:55:49 +09:00
|
|
|
|
- ✅ **Everything is Box理論の威力実証!** 🎉
|
|
|
|
|
|
|
2025-08-18 00:33:01 +09:00
|
|
|
|
### ✅ **Day 4 完了!** (2025-08-17)
|
|
|
|
|
|
**目標**: プラグインシステム基盤実装
|
2025-08-17 21:09:32 +09:00
|
|
|
|
|
2025-08-18 00:33:01 +09:00
|
|
|
|
**実装完了** (100%達成!):
|
2025-08-17 21:09:32 +09:00
|
|
|
|
- ✅ FileBoxプラグイン設計: open/read/write/close API設計
|
|
|
|
|
|
- ✅ FileBoxプラグイン実装: ハンドル管理・ファイル操作実装
|
2025-08-17 22:05:47 +09:00
|
|
|
|
- ✅ **プラグインシステム設計統合**: gemini先生とcodex先生の提案を統合
|
|
|
|
|
|
- [Box プラグインシステム設計](../説明書/reference/box-design/plugin-system.md) 作成
|
|
|
|
|
|
- YAML署名DSL仕様確定
|
|
|
|
|
|
- nyash.tomlによる透過的置き換え設計
|
2025-08-18 00:33:01 +09:00
|
|
|
|
- ✅ nyash.tomlパーサー実装(シンプル版)
|
|
|
|
|
|
- ✅ PluginBoxプロキシ実装(最小版)
|
|
|
|
|
|
- ✅ BoxFactoryRegistry: 透過的ビルトイン↔プラグイン切り替え
|
|
|
|
|
|
- ✅ libloadingプラグイン動的ロード基盤
|
|
|
|
|
|
- ✅ **プラグインシステム統合テスト(14/14合格!)** 🎉
|
|
|
|
|
|
|
2025-08-18 08:34:19 +09:00
|
|
|
|
### 🎯 **Day 5 一時中断** (2025-08-18)
|
2025-08-18 00:33:01 +09:00
|
|
|
|
**目標**: 実際のプラグインライブラリ作成と統合
|
|
|
|
|
|
|
|
|
|
|
|
**実装戦略**:
|
|
|
|
|
|
- **段階的アプローチ**: ビルトインFileBox残して並行運用
|
|
|
|
|
|
- **透過的切り替え**: nyash.tomlで動的選択
|
|
|
|
|
|
- **完全実証**: BID-FFIシステムの実動作確認
|
|
|
|
|
|
|
|
|
|
|
|
**完了タスク**:
|
|
|
|
|
|
- ✅ FileBoxプラグイン用クレート作成(独立ライブラリ)
|
|
|
|
|
|
- ✅ C API実装とエクスポート(libnyash_filebox_plugin.so生成)
|
|
|
|
|
|
- ✅ Nyashインタープリターのプラグインロード統合
|
|
|
|
|
|
- ✅ 透過的切り替え実動作確認(PluginBox生成確認)
|
|
|
|
|
|
|
2025-08-18 08:34:19 +09:00
|
|
|
|
**中断理由**:
|
|
|
|
|
|
- 🚨 **古いプラグインシステムのコードが混在していた**
|
|
|
|
|
|
- 🔧 ソースコードをcommit 3f7d71f(古いプラグイン実装前)に巻き戻し
|
|
|
|
|
|
- 📚 docsフォルダは最新状態を維持
|
|
|
|
|
|
- ✅ nyashバイナリの基本動作確認完了
|
|
|
|
|
|
|
|
|
|
|
|
**再開時の作業**:
|
|
|
|
|
|
- ⏳ BID-FFIシステムをクリーンに再実装
|
|
|
|
|
|
- ⏳ PluginBoxのtoString等メソッド実装
|
2025-08-18 00:33:01 +09:00
|
|
|
|
- ⏳ 実際のファイル操作メソッド(open/read/write)動作確認
|
|
|
|
|
|
|
|
|
|
|
|
### 🎯 今週の実装計画(段階的戦略に更新)
|
2025-08-17 18:53:34 +09:00
|
|
|
|
- **Day 1**: ✅ BID-1基盤実装(TLV仕様、Handle構造体、エンコード/デコード)
|
2025-08-17 19:02:51 +09:00
|
|
|
|
- **Day 2**: ✅ メタデータAPI実装(init/abi/shutdown、HostVtable、レジストリ)
|
2025-08-17 21:09:32 +09:00
|
|
|
|
- **Day 3**: ✅ 既存Box統合(StringBox/IntegerBox/FutureBoxブリッジ)**100%完了!**
|
2025-08-18 00:33:01 +09:00
|
|
|
|
- **Day 4**: ✅ プラグインシステム基盤(nyash.toml、PluginBox、BoxFactory)**100%完了!**
|
|
|
|
|
|
- **Day 5**: ⏳ 実際のプラグインライブラリ作成(.so/.dll、Nyash統合)**進行中!**
|
|
|
|
|
|
- **Day 6-7**: 実動作実証とドキュメント(透過的切り替え、開発ガイド)
|
2025-08-15 20:31:14 +09:00
|
|
|
|
|
2025-08-17 17:31:46 +09:00
|
|
|
|
### 🔑 技術的決定事項
|
|
|
|
|
|
- ポインタ: `usize`(プラットフォーム依存)
|
|
|
|
|
|
- アライメント: 8バイト境界
|
|
|
|
|
|
- 単一エントリーポイント: `nyash_plugin_invoke`
|
|
|
|
|
|
- ターゲット: Linux x86-64限定
|
2025-08-15 20:31:14 +09:00
|
|
|
|
|
2025-08-17 17:31:46 +09:00
|
|
|
|
## ✅ **完了済み主要成果**
|
2025-08-16 17:39:04 +09:00
|
|
|
|
|
2025-08-17 17:31:46 +09:00
|
|
|
|
### **MIR 35→26命令削減** (2025-08-17)
|
|
|
|
|
|
- 実装期間: 1日(予定5週間の5%)
|
|
|
|
|
|
- 成果: 26命令体系確立、全バックエンド対応
|
|
|
|
|
|
- 詳細: [mir-26-specification.md](../説明書/reference/mir-26-specification.md)
|
2025-08-16 17:39:04 +09:00
|
|
|
|
|
2025-08-17 17:31:46 +09:00
|
|
|
|
### **Phase 9.75 RwLock変換** (完了)
|
|
|
|
|
|
- Arc<Mutex> → Arc<RwLock>全Box型変換
|
|
|
|
|
|
- 性能改善達成
|
2025-08-16 17:39:04 +09:00
|
|
|
|
|
2025-08-17 17:31:46 +09:00
|
|
|
|
### **Phase 9.75e using nyashstd** (完了)
|
|
|
|
|
|
- 標準ライブラリ統合
|
|
|
|
|
|
- リテラル自動変換実装
|
2025-08-16 17:39:04 +09:00
|
|
|
|
|
2025-08-17 17:31:46 +09:00
|
|
|
|
### **Phase 9.75j 警告削減** (完了)
|
|
|
|
|
|
- 106個→0個(100%削減)
|
2025-08-16 17:39:04 +09:00
|
|
|
|
|
2025-08-17 17:31:46 +09:00
|
|
|
|
## 🔮 **次期優先タスク**
|
2025-08-16 17:39:04 +09:00
|
|
|
|
|
2025-08-17 17:31:46 +09:00
|
|
|
|
1. **Phase 8.6: VM性能改善**(緊急)
|
|
|
|
|
|
- 問題: VMがインタープリターより0.9倍遅い
|
|
|
|
|
|
- 目標: 2倍以上高速化
|
|
|
|
|
|
- 詳細: [phase_8_6_vm_performance_improvement.md](../予定/native-plan/issues/phase_8_6_vm_performance_improvement.md)
|
2025-08-16 17:39:04 +09:00
|
|
|
|
|
2025-08-17 17:31:46 +09:00
|
|
|
|
2. **Phase 9: JIT実装**
|
|
|
|
|
|
- VM改善後の次ステップ
|
2025-08-16 17:39:04 +09:00
|
|
|
|
|
2025-08-17 17:31:46 +09:00
|
|
|
|
3. **Phase 10: LLVM Direct AOT**
|
|
|
|
|
|
- 目標: 100-1000倍高速化
|
|
|
|
|
|
- 期間: 4-6ヶ月
|
2025-08-16 17:39:04 +09:00
|
|
|
|
|
2025-08-17 17:31:46 +09:00
|
|
|
|
## 📊 **プロジェクト統計**
|
2025-08-16 17:39:04 +09:00
|
|
|
|
|
2025-08-17 17:31:46 +09:00
|
|
|
|
- **実行モード**: インタープリター/VM/WASM/AOT(開発中)
|
2025-08-18 00:33:01 +09:00
|
|
|
|
- **Box型数**: 16種類(すべてRwLock統一)+ プラグインBox対応
|
2025-08-17 17:31:46 +09:00
|
|
|
|
- **MIR命令数**: 26(最適化済み)
|
|
|
|
|
|
- **ビルド時間**: 2分以上(改善中)
|
2025-08-18 00:33:01 +09:00
|
|
|
|
- **プラグインシステム**: BID-FFI 90%実装完了!
|
2025-08-16 17:39:04 +09:00
|
|
|
|
|
2025-08-17 17:31:46 +09:00
|
|
|
|
## 🔧 **開発ガイドライン**
|
2025-08-16 17:39:04 +09:00
|
|
|
|
|
2025-08-17 17:31:46 +09:00
|
|
|
|
### クイックリファレンス
|
|
|
|
|
|
- [CLAUDE.md](../CLAUDE.md) - 開発者向けガイド
|
|
|
|
|
|
- [copilot_issues.txt](../予定/native-plan/copilot_issues.txt) - Phase順開発計画
|
|
|
|
|
|
- [syntax-cheatsheet.md](../quick-reference/syntax-cheatsheet.md) - 構文早見表
|
2025-08-16 17:39:04 +09:00
|
|
|
|
|
2025-08-17 17:31:46 +09:00
|
|
|
|
### テスト実行
|
|
|
|
|
|
```bash
|
|
|
|
|
|
# リリースビルド(推奨)
|
|
|
|
|
|
cargo build --release -j32
|
2025-08-16 17:39:04 +09:00
|
|
|
|
|
2025-08-17 17:31:46 +09:00
|
|
|
|
# 実行
|
|
|
|
|
|
./target/release/nyash program.nyash
|
2025-08-16 17:39:04 +09:00
|
|
|
|
|
2025-08-17 17:31:46 +09:00
|
|
|
|
# ベンチマーク
|
|
|
|
|
|
./target/release/nyash --benchmark --iterations 100
|
2025-08-16 17:39:04 +09:00
|
|
|
|
```
|
2025-08-15 20:31:14 +09:00
|
|
|
|
|
2025-08-10 15:15:10 +09:00
|
|
|
|
---
|
2025-08-18 09:41:41 +09:00
|
|
|
|
**最終更新**: 2025-08-18 10:00 JST
|
|
|
|
|
|
**次回レビュー**: 2025-08-18(Nyash統合開始時)
|
2025-08-18 08:34:19 +09:00
|
|
|
|
|
|
|
|
|
|
## 🎯 **現在の状況** (2025-08-18)
|
|
|
|
|
|
|
2025-08-18 09:41:41 +09:00
|
|
|
|
### ✅ Step 1-3 完了!BID-FFI基盤実装成功
|
|
|
|
|
|
|
|
|
|
|
|
#### 達成した重要な設計原則
|
|
|
|
|
|
1. **Box名非決め打ち**: プラグインが「私はFileBoxです」と宣言
|
|
|
|
|
|
2. **汎用的設計**: plugin-testerは任意のプラグインに対応
|
|
|
|
|
|
3. **メモリ管理明確化**: birth/finiライフサイクル実装
|
|
|
|
|
|
|
|
|
|
|
|
#### 実装完了項目
|
|
|
|
|
|
- ✅ **FileBoxプラグイン**: 293KB .soファイル生成、6メソッド実装
|
|
|
|
|
|
- ✅ **nyash.toml**: プラグイン設定ファイル(FileBox = "nyash-filebox-plugin")
|
|
|
|
|
|
- ✅ **plugin-tester**: 診断ツール完成、メソッド一覧表示機能付き
|
|
|
|
|
|
|
|
|
|
|
|
### テスト結果
|
|
|
|
|
|
```
|
|
|
|
|
|
Plugin Information:
|
|
|
|
|
|
Box Type: FileBox (ID: 6) ← プラグインから取得!
|
|
|
|
|
|
Methods: 6
|
|
|
|
|
|
- birth [ID: 0, Sig: 0xBEEFCAFE] (constructor)
|
|
|
|
|
|
- open [ID: 1, Sig: 0x12345678]
|
|
|
|
|
|
- read [ID: 2, Sig: 0x87654321]
|
|
|
|
|
|
- write [ID: 3, Sig: 0x11223344]
|
|
|
|
|
|
- close [ID: 4, Sig: 0xABCDEF00]
|
|
|
|
|
|
- fini [ID: 4294967295, Sig: 0xDEADBEEF] (destructor)
|
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
### 実装完了ステップ
|
|
|
|
|
|
|
|
|
|
|
|
#### ✅ **Step 1: FileBoxプラグイン単体作成**
|
|
|
|
|
|
- ✅ plugins/nyash-filebox-plugin/Cargo.toml作成
|
|
|
|
|
|
- ✅ C FFI実装(birth/fini含む)
|
|
|
|
|
|
- ✅ 単体でビルド確認(293KB .soファイル生成)
|
|
|
|
|
|
|
|
|
|
|
|
#### ✅ **Step 2: nyash.toml設定ファイル作成**
|
|
|
|
|
|
- ✅ シンプルな設定ファイル作成
|
|
|
|
|
|
- ✅ FileBox = "nyash-filebox-plugin"の設定
|
|
|
|
|
|
- ✅ プラグイン検索パス定義
|
|
|
|
|
|
|
|
|
|
|
|
#### ✅ **Step 3: プラグインテスター/ローダー作成**
|
|
|
|
|
|
- ✅ **独立したテストツール** `plugin-tester`作成
|
|
|
|
|
|
- ✅ Box名を決め打ちしない汎用設計
|
|
|
|
|
|
- ✅ 実装済み機能:
|
|
|
|
|
|
- プラグインロードチェック ✅
|
|
|
|
|
|
- nyash_plugin_init呼び出し確認 ✅
|
|
|
|
|
|
- メソッド一覧表示 ✅
|
|
|
|
|
|
- ABI version確認 ✅
|
|
|
|
|
|
- ⏳ 今後の拡張予定:
|
2025-08-18 08:51:42 +09:00
|
|
|
|
- birth/finiライフサイクルテスト
|
|
|
|
|
|
- メモリリーク検出(valgrind連携)
|
|
|
|
|
|
- TLVエンコード/デコード検証
|
|
|
|
|
|
|
2025-08-18 09:41:41 +09:00
|
|
|
|
### 🎯 **次のステップ: Step 4 - Nyashとの統合**
|
|
|
|
|
|
|
|
|
|
|
|
#### 実装計画
|
|
|
|
|
|
1. **src/bid/モジュール作成**
|
|
|
|
|
|
- TLVエンコード/デコード実装
|
|
|
|
|
|
- BidHandle構造体定義
|
|
|
|
|
|
- エラーコード定義
|
|
|
|
|
|
|
|
|
|
|
|
2. **プラグインローダー実装**
|
|
|
|
|
|
- nyash.tomlパーサー(簡易版)
|
|
|
|
|
|
- libloadingによる動的ロード
|
|
|
|
|
|
- プラグイン初期化・シャットダウン管理
|
|
|
|
|
|
|
|
|
|
|
|
3. **BoxFactoryRegistry実装**
|
|
|
|
|
|
- ビルトインBox vs プラグインBoxの透過的切り替え
|
|
|
|
|
|
- Box名 → プラグイン名マッピング
|
|
|
|
|
|
- new FileBox()時の動的ディスパッチ
|
|
|
|
|
|
|
|
|
|
|
|
4. **PluginBoxプロキシ実装**
|
|
|
|
|
|
- NyashBoxトレイト実装
|
|
|
|
|
|
- メソッド呼び出しをFFI経由で転送
|
|
|
|
|
|
- birth/finiライフサイクル管理(Dropトレイト)
|
|
|
|
|
|
|
|
|
|
|
|
5. **統合テスト**
|
|
|
|
|
|
- FileBoxのビルトイン版とプラグイン版の動作比較
|
|
|
|
|
|
- nyash.tomlありなしでの切り替え確認
|
|
|
|
|
|
- メモリリークチェック
|
2025-08-18 08:51:42 +09:00
|
|
|
|
|
|
|
|
|
|
### 仕様更新完了
|
|
|
|
|
|
- ✅ birth/finiライフサイクル管理を仕様書に追加
|
|
|
|
|
|
- ✅ メモリ所有権ルールを明確化
|
|
|
|
|
|
- ✅ プラグインが割り当てたメモリはプラグインが解放する原則
|
|
|
|
|
|
|
2025-08-18 09:41:41 +09:00
|
|
|
|
### 現在のディレクトリ構造
|
2025-08-18 08:51:42 +09:00
|
|
|
|
```
|
|
|
|
|
|
nyash-project/nyash/
|
|
|
|
|
|
├── plugins/
|
2025-08-18 09:41:41 +09:00
|
|
|
|
│ └── nyash-filebox-plugin/ # ✅ 実装済み
|
2025-08-18 08:51:42 +09:00
|
|
|
|
│ ├── Cargo.toml
|
2025-08-18 09:41:41 +09:00
|
|
|
|
│ ├── src/lib.rs # birth/fini含む6メソッド
|
|
|
|
|
|
│ └── .gitignore
|
2025-08-18 08:51:42 +09:00
|
|
|
|
├── tools/
|
2025-08-18 09:41:41 +09:00
|
|
|
|
│ └── plugin-tester/ # ✅ 実装済み
|
2025-08-18 08:51:42 +09:00
|
|
|
|
│ ├── Cargo.toml
|
2025-08-18 09:41:41 +09:00
|
|
|
|
│ ├── src/main.rs # 汎用プラグインチェッカー
|
|
|
|
|
|
│ └── .gitignore
|
|
|
|
|
|
├── nyash.toml # ✅ 実装済み
|
2025-08-18 08:51:42 +09:00
|
|
|
|
└── src/
|
2025-08-18 09:41:41 +09:00
|
|
|
|
└── bid/ # ⏳ Step 4で作成予定
|
|
|
|
|
|
├── mod.rs # TLV、エラーコード定義
|
|
|
|
|
|
├── loader.rs # プラグインローダー
|
|
|
|
|
|
├── registry.rs # BoxFactoryRegistry
|
|
|
|
|
|
└── plugin_box.rs # PluginBoxプロキシ
|
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
### 重要な技術的決定
|
|
|
|
|
|
1. **プラグイン識別**: プラグインが自らBox名を宣言(type_name)
|
|
|
|
|
|
2. **メソッドID**: 0=birth, MAX=fini、他は任意
|
|
|
|
|
|
3. **メモリ管理**: プラグインが割り当てたメモリはプラグインが解放
|
|
|
|
|
|
4. **エラーコード**: -1〜-5の標準エラーコード定義済み
|