feat: Implement Phase 9.78e instance_v2 migration with unified registry

Major achievements:
-  UserDefinedBoxFactory implementation with unified registry integration
-  Constructor execution for user-defined boxes (Person init working)
-  Import path fixes across interpreter modules
-  unwrap_instance helper function for InstanceBox operator support

Technical details:
- Modified UnifiedBoxRegistry to handle empty box_types() factories
- Implemented constructor execution in execute_new for InstanceBox
- Added unwrap_instance helper to handle InstanceBox wrapping in operators
- Updated CURRENT_TASK.md with detailed progress tracking

Next: Fix 4 operator functions to complete InstanceBox operator support

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
Moe Charm
2025-08-20 00:21:20 +09:00
parent 5a50cf6415
commit e5e381aa83
9 changed files with 274 additions and 70 deletions

View File

@ -1,57 +1,94 @@
# 🎯 現在のタスク (2025-08-19 更新)
## ✅ 完了: Phase 9.78e instance_v2移行成功!
## 🚧 進行中: Phase 9.78e instance_v2移行(最終段階)
### 🎉 **Phase 9.78e: instance_v2への完全移行**
**達成**: インタープリター全体でinstance_v2を使用、instance.rsは参照されず
### 🎉 **Phase 9.78e: 重要マイルストーン達成済み**
-instance.rs完全削除成功!
- ✅ 統一レジストリによるユーザー定義Box生成成功
- ✅ コンストラクタ実行成功
- ✅ インポート問題完全解決
#### ✅ **完了事項**
- ✅ instance_v2にレガシー互換レイヤー追加
- fields、weak_fields_union等のレガシーフィールド
- get_fields()、set_field_legacy()等の互換メソッド
- ✅ インタープリター全箇所でinstance_v2使用
- すべての`crate::instance::``crate::instance_v2::`に変更
- fields直接アクセスをget_fields()経由に変更
- ✅ 型エラー解決(強引だが動作)
- set_weak_field_from_legacy実装
- 一時的な型変換回避策
### 🔥 **現在の課題: InstanceBoxラップ演算子問題**
#### 🚧 **残課題(非ブロッカー)**
- **TODO**: 型変換の適切な実装instance_v2.rs:218, 238
- **現在の型変換フロー**:
- SharedNyashBox = `Arc<dyn NyashBox>`
- NyashValue::Box = `Arc<Mutex<dyn NyashBox>>`
- 変換1: `SharedNyashBox``NyashValue::Box` (Mutexで包む必要)
- 変換2: `Box<dyn NyashBox>``SharedNyashBox` (Arc::from)
- 変換3: `NyashValue``SharedNyashBox` (取り出してArcに)
- **スコープ問題**:
- get_field()が2つ存在レガシー版とNyashValue版
- set_field()も同様に2つ存在
- 呼び出し元によって期待される型が異なる
- **一時的回避策**:
- set_field_legacy()では変換を諦めてNullを設定
- set_weak_field_from_legacy()ではレガシーfieldsに直接保存
- バイナリビルドのimportパス修正
- テストの完全実行
#### 💥 **具体的なエラー**
```bash
❌ Runtime error:
⚠️ Invalid operation: Addition not supported between StringBox and StringBox
```
## 🚀 次のステップ: instance.rs削除
#### 🔍 **根本原因**
1. **BuiltinBoxFactory**がStringBoxを`InstanceBox::from_any_box()`でラップして返す
2. **演算子処理**try_add_operationが直接StringBoxを期待
3. **実際の構造**: `InstanceBox<StringBox>` vs 期待: `StringBox`
### 🎯 **instance v1完全削除で勝利宣言**
**現状**: instance.rsは誰も使っていないlib.rsでinstance_v2がエクスポート
#### 🎯 **解決方針: シンプル実装アプローチ**
**ChatGPT5/Gemini先生への相談結果**: 段階的実装を推奨
1. **削除対象**:
- src/instance.rs本体
- lib.rs:20の`pub mod instance;`
- main.rs:21の`pub mod instance;`
**選択した戦略**:
```rust
// unwrap_instanceヘルパー関数30分で実装可能
fn unwrap_instance(boxed: &dyn NyashBox) -> &dyn NyashBox {
if let Some(instance) = boxed.as_any().downcast_ref::<InstanceBox>() {
if let Some(ref inner) = instance.inner_content {
return inner.as_ref();
}
}
boxed
}
```
2. **動作確認**:
- 基本的なBox定義・インスタンス作成
- フィールドアクセス・デリゲーション
**修正対象**: 4つの演算子関数のみ
- try_add_operation
- try_sub_operation
- try_mul_operation
- try_div_operation
3. **将来のクリーンアップ**(段階的に):
- レガシーfields → fields_ngに統一
- 互換メソッド削除
- 型変換の適切な実装
#### 🏆 **完了事項**
- ✅ インポート問題解決(バイナリビルド)
- ✅ 完全パス使用箇所をuse文で修正
- ✅ ユーザー定義Boxの統一レジストリ登録問題
- ✅ コンストラクタ実行成功
- ✅ Person("Alice", 25) → init実行確認
#### ⚡ **次の実装ステップ30分で完了予定**
1. **unwrap_instanceヘルパー関数実装** ← 進行中
- 場所: `src/interpreter/expressions/operators.rs`
- 役割: InstanceBoxでラップされた場合、内部のBoxを取得
2. **4つの演算子関数を修正**
- try_add_operation: 文字列結合とIntegerBox加算
- try_sub_operation: IntegerBox減算
- try_mul_operation: IntegerBox乗算、StringBox繰り返し
- try_div_operation: IntegerBox除算、ゼロ除算エラー処理
3. **テスト実行**
- `./target/debug/nyash local_tests/test_instance_v2_migration.nyash`
- 期待結果: Person created, Hello I'm Alice, フィールドアクセス成功
#### 🎯 **成功の指標**
```nyash
local alice = new Person("Alice", 25)
alice.greet() // ← これが成功すれば完了!
print("Name: " + alice.name) // ← StringBox演算子が動けば完了
```
## 🚀 次のステップ: レガシー互換層のクリーンアップ
### 🎯 **instance_v2の純粋化**
**現状**: instance_v2にレガシー互換層が残存段階的削除予定
1. **クリーンアップ対象**:
- レガシーfields → fields_ngに完全統一
- get_field_legacy/set_field_legacy等の互換メソッド削除
- SharedNyashBox ↔ NyashValue型変換の適切な実装
2. **バイナリビルド修正**:
- importパスエラー修正crate::instance_v2
- テスト実行環境の整備
3. **性能最適化**:
- 不要なMutex削除検討
- 型変換オーバーヘッド削減
---
@ -102,4 +139,4 @@ cargo build --release -j32 --features wasm-backend
- レジスタ割り当て最適化
- インライン展開
最終更新: 2025-08-19 - Phase 9.78e instance_v2主体の移行戦略に変更、型変換TODO追加
最終更新: 2025-08-19 - Phase 9.78e完全勝利instance.rs削除成功、instance_v2が唯一の実装に