feat: Phase 15.5 Week 1完了!llvmlite革命&環境変数完全整理
✅ llvmlite統一Call基盤革命達成 - mir_call.py: delegate→真の統一実装(6種Callee完全対応) - Global/Method/Constructor/Closure/Value/Extern統一処理 - 実際のLLVMハーネス動作確認(モックルート完全回避) ✅ 環境変数体系完全整理 - CLAUDE.md: モックルート回避設定完全文書化 - 複雑な環境変数組み合わせの成功パターン確立 ✅ Phase 15.5ドキュメント体系確立 - 実装状況追跡システム構築 - Week 1→2移行準備完了 🎯 Week 2開始準備: JSON出力統一→mir_json_emit.rs実装へ 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
249
docs/development/roadmap/phases/phase-15.5/risk-analysis.md
Normal file
249
docs/development/roadmap/phases/phase-15.5/risk-analysis.md
Normal file
@ -0,0 +1,249 @@
|
||||
# Phase 15.5 リスク分析と対策
|
||||
|
||||
**大規模基盤変更における潜在的リスクと対応戦略**
|
||||
|
||||
## 🚨 高リスク項目
|
||||
|
||||
### 1. 型安全性の喪失
|
||||
|
||||
**リスク**: JSON化により型チェックが弱くなる
|
||||
**影響度**: 高(バグ検出能力低下)
|
||||
**確率**: 中
|
||||
|
||||
**対策**:
|
||||
```rust
|
||||
// 型安全ビューの維持
|
||||
pub struct TypedJsonView<'a> {
|
||||
json: &'a JsonValue,
|
||||
type_registry: &'a TypeRegistry,
|
||||
}
|
||||
|
||||
impl<'a> TypedJsonView<'a> {
|
||||
fn get_value(&self, id: ValueId) -> TypedValue {
|
||||
// 型安全なアクセスを保証
|
||||
}
|
||||
}
|
||||
```
|
||||
|
||||
**検証方法**:
|
||||
- [ ] 型エラーの検出率比較(移行前後)
|
||||
- [ ] 実行時エラーの増減監視
|
||||
- [ ] 静的解析ツールでの型安全性確認
|
||||
|
||||
### 2. パフォーマンス劣化
|
||||
|
||||
**リスク**: JSON解析コストによる実行速度低下
|
||||
**影響度**: 高(ユーザー体験悪化)
|
||||
**確率**: 中
|
||||
|
||||
**対策**:
|
||||
```rust
|
||||
// 遅延解析 + キャッシュ戦略
|
||||
pub struct CachedJsonMir {
|
||||
json: JsonValue,
|
||||
parsed_cache: HashMap<String, ParsedFunction>,
|
||||
}
|
||||
|
||||
impl CachedJsonMir {
|
||||
fn get_function(&mut self, name: &str) -> &ParsedFunction {
|
||||
self.parsed_cache.entry(name.to_string())
|
||||
.or_insert_with(|| self.parse_function(name))
|
||||
}
|
||||
}
|
||||
```
|
||||
|
||||
**ベンチマーク計画**:
|
||||
- [ ] 大規模プログラムの実行時間測定
|
||||
- [ ] メモリ使用量の比較
|
||||
- [ ] コンパイル時間の測定
|
||||
|
||||
### 3. 互換性破綻
|
||||
|
||||
**リスク**: 既存機能が動作しなくなる
|
||||
**影響度**: 極高(開発停止)
|
||||
**確率**: 中
|
||||
|
||||
**対策**:
|
||||
```bash
|
||||
# 段階的フラグ制御
|
||||
NYASH_JSON_VERSION=v0 # 既存互換
|
||||
NYASH_JSON_VERSION=v1 # 統一Call対応
|
||||
NYASH_JSON_VERSION=auto # 自動選択
|
||||
```
|
||||
|
||||
**互換性マトリクス**:
|
||||
| 機能 | v0互換 | v1対応 | テスト状況 |
|
||||
|------|--------|--------|------------|
|
||||
| print文 | ✅ | ✅ | 完了 |
|
||||
| BoxCall | ✅ | 🔄 | 進行中 |
|
||||
| ExternCall | ✅ | ⏳ | 未着手 |
|
||||
|
||||
### 4. JSON仕様の複雑化
|
||||
|
||||
**リスク**: JSON v1が複雑すぎて保守困難
|
||||
**影響度**: 中(保守コスト増)
|
||||
**確率**: 高
|
||||
|
||||
**対策**:
|
||||
```json
|
||||
// 最小限の拡張
|
||||
{
|
||||
"version": 1,
|
||||
"extensions": ["unified_call"], // 機能を明示
|
||||
"call": {
|
||||
"callee": { "kind": "Global", "name": "print" },
|
||||
"args": [42]
|
||||
}
|
||||
}
|
||||
```
|
||||
|
||||
**設計原則**:
|
||||
- 既存v0との差分を最小化
|
||||
- 拡張可能だが必須でない構造
|
||||
- 人間が読めるシンプルさ維持
|
||||
|
||||
---
|
||||
|
||||
## ⚠️ 中リスク項目
|
||||
|
||||
### 5. 開発リソース不足
|
||||
|
||||
**リスク**: Phase 15.5完了前にリソース枯渇
|
||||
**影響度**: 高(セルフホスティング遅延)
|
||||
**確率**: 中
|
||||
|
||||
**対策**:
|
||||
- **MVP優先**: Phase A核心機能のみに集中
|
||||
- **並行作業**: ドキュメント・テストを先行
|
||||
- **撤退戦略**: 各段階で既存状態に戻せる設計
|
||||
|
||||
### 6. テスト網羅性不足
|
||||
|
||||
**リスク**: 移行で見落としたバグが本番で発生
|
||||
**影響度**: 中(品質低下)
|
||||
**確率**: 高
|
||||
|
||||
**対策**:
|
||||
```bash
|
||||
# 包括的テスト戦略
|
||||
./tools/phase15_5_regression_test.sh # 回帰テスト
|
||||
./tools/phase15_5_integration_test.sh # 統合テスト
|
||||
./tools/phase15_5_performance_test.sh # 性能テスト
|
||||
```
|
||||
|
||||
### 7. セルフホスティング影響
|
||||
|
||||
**リスク**: Phase 15.5がPhase 15を複雑化
|
||||
**影響度**: 高(本来目標への影響)
|
||||
**確率**: 中
|
||||
|
||||
**対策**:
|
||||
- **クリーン分離**: Phase 15.5は独立完結
|
||||
- **基盤提供**: Phase 15が確実に楽になる基盤整備
|
||||
- **優先度明確化**: セルフホスティング準備が最優先
|
||||
|
||||
---
|
||||
|
||||
## 📉 低リスク項目
|
||||
|
||||
### 8. ツール連携問題
|
||||
|
||||
**リスク**: デバッガー・プロファイラが使えなくなる
|
||||
**影響度**: 低(開発体験のみ)
|
||||
**確率**: 中
|
||||
|
||||
**対策**: 段階的対応、最後に修正
|
||||
|
||||
### 9. ドキュメント不整合
|
||||
|
||||
**リスク**: 文書が実装と乖離
|
||||
**影響度**: 低(保守のみ)
|
||||
**確率**: 高
|
||||
|
||||
**対策**: CI/CDでドキュメント同期チェック
|
||||
|
||||
---
|
||||
|
||||
## 🛡️ リスク軽減戦略
|
||||
|
||||
### 段階的実装
|
||||
```
|
||||
Phase A (核心) → Phase B (拡張) → Phase C (完成)
|
||||
↓撤退可能 ↓撤退可能 ↓撤退可能
|
||||
```
|
||||
|
||||
### 二重実装期間
|
||||
```
|
||||
期間1-2週: 旧実装 + 新実装(テスト)
|
||||
期間3-4週: 新実装 + 旧実装(バックアップ)
|
||||
期間5週以降: 新実装のみ
|
||||
```
|
||||
|
||||
### 機能フラグ制御
|
||||
```rust
|
||||
#[cfg(feature = "json_v1")]
|
||||
fn emit_unified_call() { ... }
|
||||
|
||||
#[cfg(not(feature = "json_v1"))]
|
||||
fn emit_legacy_call() { ... }
|
||||
```
|
||||
|
||||
## 🔄 撤退戦略
|
||||
|
||||
### Phase A撤退
|
||||
```bash
|
||||
# 環境変数でv0に戻す
|
||||
export NYASH_MIR_UNIFIED_CALL=0
|
||||
export NYASH_JSON_VERSION=v0
|
||||
```
|
||||
|
||||
### Phase B撤退
|
||||
```rust
|
||||
// MIR Module保持、JSON化を停止
|
||||
pub struct MirModule {
|
||||
// #[deprecated] json_wrapper: JsonWrapper,
|
||||
rust_data: RustMirData, // 復活
|
||||
}
|
||||
```
|
||||
|
||||
### Phase C撤退
|
||||
- Rust MIR完全復活
|
||||
- JSON v0をビルド時オプション化
|
||||
|
||||
## 📊 モニタリング計画
|
||||
|
||||
### メトリクス
|
||||
- **型安全性**: 静的解析警告数
|
||||
- **パフォーマンス**: 実行時間・メモリ使用量
|
||||
- **互換性**: 既存テストパス率
|
||||
- **品質**: バグ報告数・重要度
|
||||
|
||||
### 監視タイミング
|
||||
- Phase A完了時点
|
||||
- 各週のマイルストーン
|
||||
- Phase 15開始前の最終確認
|
||||
|
||||
### 判断基準
|
||||
```
|
||||
継続条件:
|
||||
- 型安全性維持 (警告増加<10%)
|
||||
- 性能劣化なし (実行時間増加<5%)
|
||||
- 互換性確保 (テストパス率=100%)
|
||||
|
||||
撤退条件:
|
||||
- 上記いずれかが達成不可能
|
||||
- スケジュール大幅遅延(2週間以上)
|
||||
- 予期しない技術的障害
|
||||
```
|
||||
|
||||
---
|
||||
|
||||
## 🎯 成功のための重要ポイント
|
||||
|
||||
1. **急がない**: 確実な段階移行
|
||||
2. **測る**: 定量的な品質確認
|
||||
3. **戻れる**: いつでも撤退可能
|
||||
4. **集中する**: Phase A核心機能優先
|
||||
5. **テストする**: 徹底的な検証
|
||||
|
||||
これらのリスク対策により、Phase 15.5は安全かつ確実に完了し、Phase 15セルフホスティングの強固な基盤となる。
|
||||
Reference in New Issue
Block a user