Files
hakorune/docs/development/current/main/phases/phase-277/README.md

139 lines
5.3 KiB
Markdown
Raw Normal View History

feat(phase277-p2): PHI環境変数統合 8個→3個 - ユーザビリティ向上 Phase 277 P2: PHI関連環境変数の統合・整理 【問題】 - PHI関連環境変数が8個に乱立 - ユーザーが覚える変数が多すぎる - 保守性が低い(関連設定が分散) 【解決】 1. debug_helper.py 新規作成(SSOT) - is_phi_debug_enabled(): 一般デバッグ(3変数統合) - is_phi_trace_enabled(): 詳細トレース(2変数統合) - is_phi_strict_enabled(): 厳格モード(既存維持) 2. 環境変数統合(8個→3個) 統合後: - NYASH_LLVM_DEBUG_PHI: 一般PHIデバッグ - NYASH_LLVM_DEBUG_PHI_TRACE: 詳細トレース - NYASH_LLVM_PHI_STRICT: 厳格モード(既存維持) 統合前(廃止予定): - NYASH_LLVM_PHI_DEBUG → NYASH_LLVM_DEBUG_PHI - NYASH_PHI_TYPE_DEBUG → NYASH_LLVM_DEBUG_PHI - NYASH_PHI_ORDERING_DEBUG → NYASH_LLVM_DEBUG_PHI - NYASH_LLVM_TRACE_PHI → NYASH_LLVM_DEBUG_PHI_TRACE - NYASH_LLVM_VMAP_TRACE → NYASH_LLVM_DEBUG_PHI_TRACE 3. 後方互換性対応 - 旧環境変数使用時に非推奨警告表示 - Phase 278 で削除予定 【効果】 - ✅ ユーザビリティ向上: 覚える変数 8個→3個(62%削減) - ✅ 保守性向上: 環境変数チェック 30+箇所→1箇所(SSOT) - ✅ ドキュメント簡潔化: environment-variables.md 整理 - ✅ SSOT原則適用: debug_helper.py に環境変数ロジック集約 【影響範囲】 - 新規: debug_helper.py (SSOT) - 修正: 9ファイル(PHI関連Python) - ドキュメント: environment-variables.md, 10-Now.md 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2025-12-22 13:57:33 +09:00
# Phase 277: PHI関連改善シリーズ
## 概要
Phase 275/276で完了したFloat型PHI対応・型取得SSOT化の後続改善として、PHI関連の環境変数統合・ドキュメント整備を実施。
feat(llvm/phi): Phase 277 P1 - fail-fast validation for PHI strict mode ## Summary Implemented fail-fast validation for PHI ordering and value resolution in strict mode. ## Changes ### P1-1: Strict mode for "PHI after terminator" - File: `src/llvm_py/phi_wiring/wiring.py::ensure_phi` - Behavior: `NYASH_LLVM_PHI_STRICT=1` → RuntimeError if PHI created after terminator - Default: Warning only (no regression) ### P1-2: Strict mode for "fallback 0" - File: `src/llvm_py/phi_wiring/wiring.py::wire_incomings` - Behavior: Strict mode forbids silent fallback to 0 (2 locations) - Location 1: Unresolvable incoming value - Location 2: Type coercion failure - Error messages point to next debug file: `llvm_builder.py::_value_at_end_i64` ### P1-3: Connect verify_phi_ordering() to execution path - File: `src/llvm_py/builders/function_lower.py` - Behavior: Verify PHI ordering after all instructions emitted - Debug mode: Shows "✅ All N blocks have correct PHI ordering" - Strict mode: Raises RuntimeError with block list if violations found ## Testing ✅ Test 1: strict=OFF - passes without errors ✅ Test 2: strict=ON - passes without errors (no violations in test fixtures) ✅ Test 3: debug mode - verify_phi_ordering() connected and running ## Scope - LLVM harness (Python) changes only - No new environment variables (uses existing 3 from Phase 277 P2) - No JoinIR/Rust changes (root fix is Phase 279) - Default behavior unchanged (strict mode opt-in) ## Next Steps - Phase 278: Remove deprecated env var support - Phase 279: Root fix - unify "2本のコンパイラ" pipelines 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2025-12-22 14:48:37 +09:00
このPhaseの狙いは「PHIまわりの迷子を無くす」こと
- どの層が何を決めるかSSOTを固定する
- PHI順序/配線の違反を “後段で壊れる” ではなく “原因で止まる” に寄せる
- そして根治として「2本のコンパイラパイプライン差による二重バグ」を Phase 279 で潰せるように導線を引く
入口(関連):
- Now: `docs/development/current/main/10-Now.md`
- Backlog: `docs/development/current/main/30-Backlog.md`
feat(phase277-p2): PHI環境変数統合 8個→3個 - ユーザビリティ向上 Phase 277 P2: PHI関連環境変数の統合・整理 【問題】 - PHI関連環境変数が8個に乱立 - ユーザーが覚える変数が多すぎる - 保守性が低い(関連設定が分散) 【解決】 1. debug_helper.py 新規作成(SSOT) - is_phi_debug_enabled(): 一般デバッグ(3変数統合) - is_phi_trace_enabled(): 詳細トレース(2変数統合) - is_phi_strict_enabled(): 厳格モード(既存維持) 2. 環境変数統合(8個→3個) 統合後: - NYASH_LLVM_DEBUG_PHI: 一般PHIデバッグ - NYASH_LLVM_DEBUG_PHI_TRACE: 詳細トレース - NYASH_LLVM_PHI_STRICT: 厳格モード(既存維持) 統合前(廃止予定): - NYASH_LLVM_PHI_DEBUG → NYASH_LLVM_DEBUG_PHI - NYASH_PHI_TYPE_DEBUG → NYASH_LLVM_DEBUG_PHI - NYASH_PHI_ORDERING_DEBUG → NYASH_LLVM_DEBUG_PHI - NYASH_LLVM_TRACE_PHI → NYASH_LLVM_DEBUG_PHI_TRACE - NYASH_LLVM_VMAP_TRACE → NYASH_LLVM_DEBUG_PHI_TRACE 3. 後方互換性対応 - 旧環境変数使用時に非推奨警告表示 - Phase 278 で削除予定 【効果】 - ✅ ユーザビリティ向上: 覚える変数 8個→3個(62%削減) - ✅ 保守性向上: 環境変数チェック 30+箇所→1箇所(SSOT) - ✅ ドキュメント簡潔化: environment-variables.md 整理 - ✅ SSOT原則適用: debug_helper.py に環境変数ロジック集約 【影響範囲】 - 新規: debug_helper.py (SSOT) - 修正: 9ファイル(PHI関連Python) - ドキュメント: environment-variables.md, 10-Now.md 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2025-12-22 13:57:33 +09:00
---
## サブフェーズ一覧
### Phase 277 P0: PHI型推論ドキュメント整備予定
- 目的: Phase 275/276で実装したPHI型推論ロジックのドキュメント化
- 内容:
- MIR型伝播 → LLVM IR型生成のフロー図
feat(llvm/phi): Phase 277 P1 - fail-fast validation for PHI strict mode ## Summary Implemented fail-fast validation for PHI ordering and value resolution in strict mode. ## Changes ### P1-1: Strict mode for "PHI after terminator" - File: `src/llvm_py/phi_wiring/wiring.py::ensure_phi` - Behavior: `NYASH_LLVM_PHI_STRICT=1` → RuntimeError if PHI created after terminator - Default: Warning only (no regression) ### P1-2: Strict mode for "fallback 0" - File: `src/llvm_py/phi_wiring/wiring.py::wire_incomings` - Behavior: Strict mode forbids silent fallback to 0 (2 locations) - Location 1: Unresolvable incoming value - Location 2: Type coercion failure - Error messages point to next debug file: `llvm_builder.py::_value_at_end_i64` ### P1-3: Connect verify_phi_ordering() to execution path - File: `src/llvm_py/builders/function_lower.py` - Behavior: Verify PHI ordering after all instructions emitted - Debug mode: Shows "✅ All N blocks have correct PHI ordering" - Strict mode: Raises RuntimeError with block list if violations found ## Testing ✅ Test 1: strict=OFF - passes without errors ✅ Test 2: strict=ON - passes without errors (no violations in test fixtures) ✅ Test 3: debug mode - verify_phi_ordering() connected and running ## Scope - LLVM harness (Python) changes only - No new environment variables (uses existing 3 from Phase 277 P2) - No JoinIR/Rust changes (root fix is Phase 279) - Default behavior unchanged (strict mode opt-in) ## Next Steps - Phase 278: Remove deprecated env var support - Phase 279: Root fix - unify "2本のコンパイラ" pipelines 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2025-12-22 14:48:37 +09:00
- type_helper.pyLLVM harness 側の型取得SSOTの設計ドキュメント
feat(phase277-p2): PHI環境変数統合 8個→3個 - ユーザビリティ向上 Phase 277 P2: PHI関連環境変数の統合・整理 【問題】 - PHI関連環境変数が8個に乱立 - ユーザーが覚える変数が多すぎる - 保守性が低い(関連設定が分散) 【解決】 1. debug_helper.py 新規作成(SSOT) - is_phi_debug_enabled(): 一般デバッグ(3変数統合) - is_phi_trace_enabled(): 詳細トレース(2変数統合) - is_phi_strict_enabled(): 厳格モード(既存維持) 2. 環境変数統合(8個→3個) 統合後: - NYASH_LLVM_DEBUG_PHI: 一般PHIデバッグ - NYASH_LLVM_DEBUG_PHI_TRACE: 詳細トレース - NYASH_LLVM_PHI_STRICT: 厳格モード(既存維持) 統合前(廃止予定): - NYASH_LLVM_PHI_DEBUG → NYASH_LLVM_DEBUG_PHI - NYASH_PHI_TYPE_DEBUG → NYASH_LLVM_DEBUG_PHI - NYASH_PHI_ORDERING_DEBUG → NYASH_LLVM_DEBUG_PHI - NYASH_LLVM_TRACE_PHI → NYASH_LLVM_DEBUG_PHI_TRACE - NYASH_LLVM_VMAP_TRACE → NYASH_LLVM_DEBUG_PHI_TRACE 3. 後方互換性対応 - 旧環境変数使用時に非推奨警告表示 - Phase 278 で削除予定 【効果】 - ✅ ユーザビリティ向上: 覚える変数 8個→3個(62%削減) - ✅ 保守性向上: 環境変数チェック 30+箇所→1箇所(SSOT) - ✅ ドキュメント簡潔化: environment-variables.md 整理 - ✅ SSOT原則適用: debug_helper.py に環境変数ロジック集約 【影響範囲】 - 新規: debug_helper.py (SSOT) - 修正: 9ファイル(PHI関連Python) - ドキュメント: environment-variables.md, 10-Now.md 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2025-12-22 13:57:33 +09:00
- PHI型推論のベストプラクティス
feat(llvm/phi): Phase 277 P1 - fail-fast validation for PHI strict mode ## Summary Implemented fail-fast validation for PHI ordering and value resolution in strict mode. ## Changes ### P1-1: Strict mode for "PHI after terminator" - File: `src/llvm_py/phi_wiring/wiring.py::ensure_phi` - Behavior: `NYASH_LLVM_PHI_STRICT=1` → RuntimeError if PHI created after terminator - Default: Warning only (no regression) ### P1-2: Strict mode for "fallback 0" - File: `src/llvm_py/phi_wiring/wiring.py::wire_incomings` - Behavior: Strict mode forbids silent fallback to 0 (2 locations) - Location 1: Unresolvable incoming value - Location 2: Type coercion failure - Error messages point to next debug file: `llvm_builder.py::_value_at_end_i64` ### P1-3: Connect verify_phi_ordering() to execution path - File: `src/llvm_py/builders/function_lower.py` - Behavior: Verify PHI ordering after all instructions emitted - Debug mode: Shows "✅ All N blocks have correct PHI ordering" - Strict mode: Raises RuntimeError with block list if violations found ## Testing ✅ Test 1: strict=OFF - passes without errors ✅ Test 2: strict=ON - passes without errors (no violations in test fixtures) ✅ Test 3: debug mode - verify_phi_ordering() connected and running ## Scope - LLVM harness (Python) changes only - No new environment variables (uses existing 3 from Phase 277 P2) - No JoinIR/Rust changes (root fix is Phase 279) - Default behavior unchanged (strict mode opt-in) ## Next Steps - Phase 278: Remove deprecated env var support - Phase 279: Root fix - unify "2本のコンパイラ" pipelines 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2025-12-22 14:48:37 +09:00
- 設計メモこのPhase配下のSSOT案:
- `docs/development/current/main/phases/phase-277/P0-DESIGN.md`
- 指示書Claude Code:
- `docs/development/current/main/phases/phase-277/P0-INSTRUCTIONS.md`
feat(phase277-p2): PHI環境変数統合 8個→3個 - ユーザビリティ向上 Phase 277 P2: PHI関連環境変数の統合・整理 【問題】 - PHI関連環境変数が8個に乱立 - ユーザーが覚える変数が多すぎる - 保守性が低い(関連設定が分散) 【解決】 1. debug_helper.py 新規作成(SSOT) - is_phi_debug_enabled(): 一般デバッグ(3変数統合) - is_phi_trace_enabled(): 詳細トレース(2変数統合) - is_phi_strict_enabled(): 厳格モード(既存維持) 2. 環境変数統合(8個→3個) 統合後: - NYASH_LLVM_DEBUG_PHI: 一般PHIデバッグ - NYASH_LLVM_DEBUG_PHI_TRACE: 詳細トレース - NYASH_LLVM_PHI_STRICT: 厳格モード(既存維持) 統合前(廃止予定): - NYASH_LLVM_PHI_DEBUG → NYASH_LLVM_DEBUG_PHI - NYASH_PHI_TYPE_DEBUG → NYASH_LLVM_DEBUG_PHI - NYASH_PHI_ORDERING_DEBUG → NYASH_LLVM_DEBUG_PHI - NYASH_LLVM_TRACE_PHI → NYASH_LLVM_DEBUG_PHI_TRACE - NYASH_LLVM_VMAP_TRACE → NYASH_LLVM_DEBUG_PHI_TRACE 3. 後方互換性対応 - 旧環境変数使用時に非推奨警告表示 - Phase 278 で削除予定 【効果】 - ✅ ユーザビリティ向上: 覚える変数 8個→3個(62%削減) - ✅ 保守性向上: 環境変数チェック 30+箇所→1箇所(SSOT) - ✅ ドキュメント簡潔化: environment-variables.md 整理 - ✅ SSOT原則適用: debug_helper.py に環境変数ロジック集約 【影響範囲】 - 新規: debug_helper.py (SSOT) - 修正: 9ファイル(PHI関連Python) - ドキュメント: environment-variables.md, 10-Now.md 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2025-12-22 13:57:33 +09:00
### Phase 277 P1: PHI順序検証強化fail-fast
feat(phase277-p2): PHI環境変数統合 8個→3個 - ユーザビリティ向上 Phase 277 P2: PHI関連環境変数の統合・整理 【問題】 - PHI関連環境変数が8個に乱立 - ユーザーが覚える変数が多すぎる - 保守性が低い(関連設定が分散) 【解決】 1. debug_helper.py 新規作成(SSOT) - is_phi_debug_enabled(): 一般デバッグ(3変数統合) - is_phi_trace_enabled(): 詳細トレース(2変数統合) - is_phi_strict_enabled(): 厳格モード(既存維持) 2. 環境変数統合(8個→3個) 統合後: - NYASH_LLVM_DEBUG_PHI: 一般PHIデバッグ - NYASH_LLVM_DEBUG_PHI_TRACE: 詳細トレース - NYASH_LLVM_PHI_STRICT: 厳格モード(既存維持) 統合前(廃止予定): - NYASH_LLVM_PHI_DEBUG → NYASH_LLVM_DEBUG_PHI - NYASH_PHI_TYPE_DEBUG → NYASH_LLVM_DEBUG_PHI - NYASH_PHI_ORDERING_DEBUG → NYASH_LLVM_DEBUG_PHI - NYASH_LLVM_TRACE_PHI → NYASH_LLVM_DEBUG_PHI_TRACE - NYASH_LLVM_VMAP_TRACE → NYASH_LLVM_DEBUG_PHI_TRACE 3. 後方互換性対応 - 旧環境変数使用時に非推奨警告表示 - Phase 278 で削除予定 【効果】 - ✅ ユーザビリティ向上: 覚える変数 8個→3個(62%削減) - ✅ 保守性向上: 環境変数チェック 30+箇所→1箇所(SSOT) - ✅ ドキュメント簡潔化: environment-variables.md 整理 - ✅ SSOT原則適用: debug_helper.py に環境変数ロジック集約 【影響範囲】 - 新規: debug_helper.py (SSOT) - 修正: 9ファイル(PHI関連Python) - ドキュメント: environment-variables.md, 10-Now.md 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2025-12-22 13:57:33 +09:00
- 目的: PHI命令の配置順序検証を強化
- 内容:
- phi_placement.py の検証ロジック強化
- LLVM IR仕様準拠チェックPHI → 非PHI → terminator
- 順序違反時のエラーメッセージ改善
feat(llvm/phi): Phase 277 P1 - fail-fast validation for PHI strict mode ## Summary Implemented fail-fast validation for PHI ordering and value resolution in strict mode. ## Changes ### P1-1: Strict mode for "PHI after terminator" - File: `src/llvm_py/phi_wiring/wiring.py::ensure_phi` - Behavior: `NYASH_LLVM_PHI_STRICT=1` → RuntimeError if PHI created after terminator - Default: Warning only (no regression) ### P1-2: Strict mode for "fallback 0" - File: `src/llvm_py/phi_wiring/wiring.py::wire_incomings` - Behavior: Strict mode forbids silent fallback to 0 (2 locations) - Location 1: Unresolvable incoming value - Location 2: Type coercion failure - Error messages point to next debug file: `llvm_builder.py::_value_at_end_i64` ### P1-3: Connect verify_phi_ordering() to execution path - File: `src/llvm_py/builders/function_lower.py` - Behavior: Verify PHI ordering after all instructions emitted - Debug mode: Shows "✅ All N blocks have correct PHI ordering" - Strict mode: Raises RuntimeError with block list if violations found ## Testing ✅ Test 1: strict=OFF - passes without errors ✅ Test 2: strict=ON - passes without errors (no violations in test fixtures) ✅ Test 3: debug mode - verify_phi_ordering() connected and running ## Scope - LLVM harness (Python) changes only - No new environment variables (uses existing 3 from Phase 277 P2) - No JoinIR/Rust changes (root fix is Phase 279) - Default behavior unchanged (strict mode opt-in) ## Next Steps - Phase 278: Remove deprecated env var support - Phase 279: Root fix - unify "2本のコンパイラ" pipelines 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2025-12-22 14:48:37 +09:00
- 検証メモこのPhase配下のSSOT案:
- `docs/development/current/main/phases/phase-277/P1-VALIDATION.md`
- 指示書Claude Code:
- `docs/development/current/main/phases/phase-277/P1-INSTRUCTIONS.md`
- 完了報告:
- `docs/development/current/main/phases/phase-277/P1-COMPLETION.md`
feat(phase277-p2): PHI環境変数統合 8個→3個 - ユーザビリティ向上 Phase 277 P2: PHI関連環境変数の統合・整理 【問題】 - PHI関連環境変数が8個に乱立 - ユーザーが覚える変数が多すぎる - 保守性が低い(関連設定が分散) 【解決】 1. debug_helper.py 新規作成(SSOT) - is_phi_debug_enabled(): 一般デバッグ(3変数統合) - is_phi_trace_enabled(): 詳細トレース(2変数統合) - is_phi_strict_enabled(): 厳格モード(既存維持) 2. 環境変数統合(8個→3個) 統合後: - NYASH_LLVM_DEBUG_PHI: 一般PHIデバッグ - NYASH_LLVM_DEBUG_PHI_TRACE: 詳細トレース - NYASH_LLVM_PHI_STRICT: 厳格モード(既存維持) 統合前(廃止予定): - NYASH_LLVM_PHI_DEBUG → NYASH_LLVM_DEBUG_PHI - NYASH_PHI_TYPE_DEBUG → NYASH_LLVM_DEBUG_PHI - NYASH_PHI_ORDERING_DEBUG → NYASH_LLVM_DEBUG_PHI - NYASH_LLVM_TRACE_PHI → NYASH_LLVM_DEBUG_PHI_TRACE - NYASH_LLVM_VMAP_TRACE → NYASH_LLVM_DEBUG_PHI_TRACE 3. 後方互換性対応 - 旧環境変数使用時に非推奨警告表示 - Phase 278 で削除予定 【効果】 - ✅ ユーザビリティ向上: 覚える変数 8個→3個(62%削減) - ✅ 保守性向上: 環境変数チェック 30+箇所→1箇所(SSOT) - ✅ ドキュメント簡潔化: environment-variables.md 整理 - ✅ SSOT原則適用: debug_helper.py に環境変数ロジック集約 【影響範囲】 - 新規: debug_helper.py (SSOT) - 修正: 9ファイル(PHI関連Python) - ドキュメント: environment-variables.md, 10-Now.md 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2025-12-22 13:57:33 +09:00
### Phase 277 P2: PHI関連環境変数の統合・整理 ✅
**完了日**: 2025-12-22
- 目的: PHI関連環境変数を **8個 → 3個** に統合
- 完了ドキュメント: `P2-COMPLETION.md`
- 達成内容:
- ✅ debug_helper.py 作成環境変数チェックのSSOT
- ✅ 3つの統合関数実装is_phi_debug_enabled 他)
- ✅ 9ファイル修正完了wiring.py, tagging.py 他)
- ✅ 後方互換性対応Phase 278で削除予定
- ✅ ドキュメント更新environment-variables.md
- 効果:
- ユーザビリティ向上(覚える変数 8個→3個、62%削減)
- 保守性向上環境変数チェックのSSOT化
- ドキュメント簡潔化
---
## 統合後の環境変数P2完了版
```bash
# PHI一般デバッグ生成・型推論・順序
NYASH_LLVM_DEBUG_PHI=1
# PHI詳細トレースwiring・vmap変化
NYASH_LLVM_DEBUG_PHI_TRACE=1
# PHI厳格モードゼロフォールバック禁止
NYASH_LLVM_PHI_STRICT=1
```
**詳細**: `docs/reference/environment-variables.md` の「PHI デバッグ関連」セクション
---
## 関連Phase
- **Phase 275**: Float型PHI対応MIR型伝播 → LLVM IR double生成
- **Phase 276**: 型取得SSOT化type_helper.py
- **Phase 278**: 後方互換性削除(旧環境変数サポート削除予定)
feat(llvm/phi): Phase 277 P1 - fail-fast validation for PHI strict mode ## Summary Implemented fail-fast validation for PHI ordering and value resolution in strict mode. ## Changes ### P1-1: Strict mode for "PHI after terminator" - File: `src/llvm_py/phi_wiring/wiring.py::ensure_phi` - Behavior: `NYASH_LLVM_PHI_STRICT=1` → RuntimeError if PHI created after terminator - Default: Warning only (no regression) ### P1-2: Strict mode for "fallback 0" - File: `src/llvm_py/phi_wiring/wiring.py::wire_incomings` - Behavior: Strict mode forbids silent fallback to 0 (2 locations) - Location 1: Unresolvable incoming value - Location 2: Type coercion failure - Error messages point to next debug file: `llvm_builder.py::_value_at_end_i64` ### P1-3: Connect verify_phi_ordering() to execution path - File: `src/llvm_py/builders/function_lower.py` - Behavior: Verify PHI ordering after all instructions emitted - Debug mode: Shows "✅ All N blocks have correct PHI ordering" - Strict mode: Raises RuntimeError with block list if violations found ## Testing ✅ Test 1: strict=OFF - passes without errors ✅ Test 2: strict=ON - passes without errors (no violations in test fixtures) ✅ Test 3: debug mode - verify_phi_ordering() connected and running ## Scope - LLVM harness (Python) changes only - No new environment variables (uses existing 3 from Phase 277 P2) - No JoinIR/Rust changes (root fix is Phase 279) - Default behavior unchanged (strict mode opt-in) ## Next Steps - Phase 278: Remove deprecated env var support - Phase 279: Root fix - unify "2本のコンパイラ" pipelines 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2025-12-22 14:48:37 +09:00
- **Phase 279**: パイプラインSSOT統一“2本のコンパイラ” 根治)
feat(phase277-p2): PHI環境変数統合 8個→3個 - ユーザビリティ向上 Phase 277 P2: PHI関連環境変数の統合・整理 【問題】 - PHI関連環境変数が8個に乱立 - ユーザーが覚える変数が多すぎる - 保守性が低い(関連設定が分散) 【解決】 1. debug_helper.py 新規作成(SSOT) - is_phi_debug_enabled(): 一般デバッグ(3変数統合) - is_phi_trace_enabled(): 詳細トレース(2変数統合) - is_phi_strict_enabled(): 厳格モード(既存維持) 2. 環境変数統合(8個→3個) 統合後: - NYASH_LLVM_DEBUG_PHI: 一般PHIデバッグ - NYASH_LLVM_DEBUG_PHI_TRACE: 詳細トレース - NYASH_LLVM_PHI_STRICT: 厳格モード(既存維持) 統合前(廃止予定): - NYASH_LLVM_PHI_DEBUG → NYASH_LLVM_DEBUG_PHI - NYASH_PHI_TYPE_DEBUG → NYASH_LLVM_DEBUG_PHI - NYASH_PHI_ORDERING_DEBUG → NYASH_LLVM_DEBUG_PHI - NYASH_LLVM_TRACE_PHI → NYASH_LLVM_DEBUG_PHI_TRACE - NYASH_LLVM_VMAP_TRACE → NYASH_LLVM_DEBUG_PHI_TRACE 3. 後方互換性対応 - 旧環境変数使用時に非推奨警告表示 - Phase 278 で削除予定 【効果】 - ✅ ユーザビリティ向上: 覚える変数 8個→3個(62%削減) - ✅ 保守性向上: 環境変数チェック 30+箇所→1箇所(SSOT) - ✅ ドキュメント簡潔化: environment-variables.md 整理 - ✅ SSOT原則適用: debug_helper.py に環境変数ロジック集約 【影響範囲】 - 新規: debug_helper.py (SSOT) - 修正: 9ファイル(PHI関連Python) - ドキュメント: environment-variables.md, 10-Now.md 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2025-12-22 13:57:33 +09:00
---
## ファイル構成
```
phase-277/
├── README.md # 本ファイルPhase 277概要
├── P0-INSTRUCTIONS.md # P0指示書Claude Code
feat(phase277-p2): PHI環境変数統合 8個→3個 - ユーザビリティ向上 Phase 277 P2: PHI関連環境変数の統合・整理 【問題】 - PHI関連環境変数が8個に乱立 - ユーザーが覚える変数が多すぎる - 保守性が低い(関連設定が分散) 【解決】 1. debug_helper.py 新規作成(SSOT) - is_phi_debug_enabled(): 一般デバッグ(3変数統合) - is_phi_trace_enabled(): 詳細トレース(2変数統合) - is_phi_strict_enabled(): 厳格モード(既存維持) 2. 環境変数統合(8個→3個) 統合後: - NYASH_LLVM_DEBUG_PHI: 一般PHIデバッグ - NYASH_LLVM_DEBUG_PHI_TRACE: 詳細トレース - NYASH_LLVM_PHI_STRICT: 厳格モード(既存維持) 統合前(廃止予定): - NYASH_LLVM_PHI_DEBUG → NYASH_LLVM_DEBUG_PHI - NYASH_PHI_TYPE_DEBUG → NYASH_LLVM_DEBUG_PHI - NYASH_PHI_ORDERING_DEBUG → NYASH_LLVM_DEBUG_PHI - NYASH_LLVM_TRACE_PHI → NYASH_LLVM_DEBUG_PHI_TRACE - NYASH_LLVM_VMAP_TRACE → NYASH_LLVM_DEBUG_PHI_TRACE 3. 後方互換性対応 - 旧環境変数使用時に非推奨警告表示 - Phase 278 で削除予定 【効果】 - ✅ ユーザビリティ向上: 覚える変数 8個→3個(62%削減) - ✅ 保守性向上: 環境変数チェック 30+箇所→1箇所(SSOT) - ✅ ドキュメント簡潔化: environment-variables.md 整理 - ✅ SSOT原則適用: debug_helper.py に環境変数ロジック集約 【影響範囲】 - 新規: debug_helper.py (SSOT) - 修正: 9ファイル(PHI関連Python) - ドキュメント: environment-variables.md, 10-Now.md 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2025-12-22 13:57:33 +09:00
├── P2-COMPLETION.md # P2完了報告
feat(llvm/phi): Phase 277 P1 - fail-fast validation for PHI strict mode ## Summary Implemented fail-fast validation for PHI ordering and value resolution in strict mode. ## Changes ### P1-1: Strict mode for "PHI after terminator" - File: `src/llvm_py/phi_wiring/wiring.py::ensure_phi` - Behavior: `NYASH_LLVM_PHI_STRICT=1` → RuntimeError if PHI created after terminator - Default: Warning only (no regression) ### P1-2: Strict mode for "fallback 0" - File: `src/llvm_py/phi_wiring/wiring.py::wire_incomings` - Behavior: Strict mode forbids silent fallback to 0 (2 locations) - Location 1: Unresolvable incoming value - Location 2: Type coercion failure - Error messages point to next debug file: `llvm_builder.py::_value_at_end_i64` ### P1-3: Connect verify_phi_ordering() to execution path - File: `src/llvm_py/builders/function_lower.py` - Behavior: Verify PHI ordering after all instructions emitted - Debug mode: Shows "✅ All N blocks have correct PHI ordering" - Strict mode: Raises RuntimeError with block list if violations found ## Testing ✅ Test 1: strict=OFF - passes without errors ✅ Test 2: strict=ON - passes without errors (no violations in test fixtures) ✅ Test 3: debug mode - verify_phi_ordering() connected and running ## Scope - LLVM harness (Python) changes only - No new environment variables (uses existing 3 from Phase 277 P2) - No JoinIR/Rust changes (root fix is Phase 279) - Default behavior unchanged (strict mode opt-in) ## Next Steps - Phase 278: Remove deprecated env var support - Phase 279: Root fix - unify "2本のコンパイラ" pipelines 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2025-12-22 14:48:37 +09:00
├── P0-DESIGN.md # P0設計ドキュメントdocs
├── P1-INSTRUCTIONS.md # P1指示書Claude Code
├── P1-VALIDATION.md # P1検証強化ドキュメントvalidation
└── P1-COMPLETION.md # P1完了報告
feat(phase277-p2): PHI環境変数統合 8個→3個 - ユーザビリティ向上 Phase 277 P2: PHI関連環境変数の統合・整理 【問題】 - PHI関連環境変数が8個に乱立 - ユーザーが覚える変数が多すぎる - 保守性が低い(関連設定が分散) 【解決】 1. debug_helper.py 新規作成(SSOT) - is_phi_debug_enabled(): 一般デバッグ(3変数統合) - is_phi_trace_enabled(): 詳細トレース(2変数統合) - is_phi_strict_enabled(): 厳格モード(既存維持) 2. 環境変数統合(8個→3個) 統合後: - NYASH_LLVM_DEBUG_PHI: 一般PHIデバッグ - NYASH_LLVM_DEBUG_PHI_TRACE: 詳細トレース - NYASH_LLVM_PHI_STRICT: 厳格モード(既存維持) 統合前(廃止予定): - NYASH_LLVM_PHI_DEBUG → NYASH_LLVM_DEBUG_PHI - NYASH_PHI_TYPE_DEBUG → NYASH_LLVM_DEBUG_PHI - NYASH_PHI_ORDERING_DEBUG → NYASH_LLVM_DEBUG_PHI - NYASH_LLVM_TRACE_PHI → NYASH_LLVM_DEBUG_PHI_TRACE - NYASH_LLVM_VMAP_TRACE → NYASH_LLVM_DEBUG_PHI_TRACE 3. 後方互換性対応 - 旧環境変数使用時に非推奨警告表示 - Phase 278 で削除予定 【効果】 - ✅ ユーザビリティ向上: 覚える変数 8個→3個(62%削減) - ✅ 保守性向上: 環境変数チェック 30+箇所→1箇所(SSOT) - ✅ ドキュメント簡潔化: environment-variables.md 整理 - ✅ SSOT原則適用: debug_helper.py に環境変数ロジック集約 【影響範囲】 - 新規: debug_helper.py (SSOT) - 修正: 9ファイル(PHI関連Python) - ドキュメント: environment-variables.md, 10-Now.md 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2025-12-22 13:57:33 +09:00
```
---
feat(llvm/phi): Phase 277 P1 - fail-fast validation for PHI strict mode ## Summary Implemented fail-fast validation for PHI ordering and value resolution in strict mode. ## Changes ### P1-1: Strict mode for "PHI after terminator" - File: `src/llvm_py/phi_wiring/wiring.py::ensure_phi` - Behavior: `NYASH_LLVM_PHI_STRICT=1` → RuntimeError if PHI created after terminator - Default: Warning only (no regression) ### P1-2: Strict mode for "fallback 0" - File: `src/llvm_py/phi_wiring/wiring.py::wire_incomings` - Behavior: Strict mode forbids silent fallback to 0 (2 locations) - Location 1: Unresolvable incoming value - Location 2: Type coercion failure - Error messages point to next debug file: `llvm_builder.py::_value_at_end_i64` ### P1-3: Connect verify_phi_ordering() to execution path - File: `src/llvm_py/builders/function_lower.py` - Behavior: Verify PHI ordering after all instructions emitted - Debug mode: Shows "✅ All N blocks have correct PHI ordering" - Strict mode: Raises RuntimeError with block list if violations found ## Testing ✅ Test 1: strict=OFF - passes without errors ✅ Test 2: strict=ON - passes without errors (no violations in test fixtures) ✅ Test 3: debug mode - verify_phi_ordering() connected and running ## Scope - LLVM harness (Python) changes only - No new environment variables (uses existing 3 from Phase 277 P2) - No JoinIR/Rust changes (root fix is Phase 279) - Default behavior unchanged (strict mode opt-in) ## Next Steps - Phase 278: Remove deprecated env var support - Phase 279: Root fix - unify "2本のコンパイラ" pipelines 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2025-12-22 14:48:37 +09:00
## 重要なSSOTどこが何を決めるか
最小の地図(迷ったらここから辿る):
- **PHI env var統合SSOT**: `src/llvm_py/phi_wiring/debug_helper.py`
- 使う側は `is_phi_debug_enabled()` / `is_phi_trace_enabled()` / `is_phi_strict_enabled()` だけを見る
- 旧 env var の撤去は Phase 278
- **LLVM harness 側の型取得SSOT**: `src/llvm_py/phi_wiring/type_helper.py`
- `get_phi_dst_type(...)``dst_type_to_llvm_type(...)` が入口
- “PHIのdst_typeをどこから取るか” をここに集約するPhase 276 P0
- **PHI placeholder を block head に作るSSOT**: `src/llvm_py/phi_wiring/wiring.py::ensure_phi`
- llvmlite は “後から命令を並べ替える” が基本できない
- よって PHI は “作るタイミング” が勝負PHI-first の契約をここで守る)
- **順序検証verifier**: `src/llvm_py/phi_placement.py`
- 現状は “並べ替え” ではなく “検証/レポート” のみllvmlite制約
- Phase 277 P1 で fail-fast 導線を強化するstrict mode の意味を強くする)
- **根治(パイプライン二重化の解消)**: `docs/development/current/main/phases/phase-279/README.md`
---
feat(phase277-p2): PHI環境変数統合 8個→3個 - ユーザビリティ向上 Phase 277 P2: PHI関連環境変数の統合・整理 【問題】 - PHI関連環境変数が8個に乱立 - ユーザーが覚える変数が多すぎる - 保守性が低い(関連設定が分散) 【解決】 1. debug_helper.py 新規作成(SSOT) - is_phi_debug_enabled(): 一般デバッグ(3変数統合) - is_phi_trace_enabled(): 詳細トレース(2変数統合) - is_phi_strict_enabled(): 厳格モード(既存維持) 2. 環境変数統合(8個→3個) 統合後: - NYASH_LLVM_DEBUG_PHI: 一般PHIデバッグ - NYASH_LLVM_DEBUG_PHI_TRACE: 詳細トレース - NYASH_LLVM_PHI_STRICT: 厳格モード(既存維持) 統合前(廃止予定): - NYASH_LLVM_PHI_DEBUG → NYASH_LLVM_DEBUG_PHI - NYASH_PHI_TYPE_DEBUG → NYASH_LLVM_DEBUG_PHI - NYASH_PHI_ORDERING_DEBUG → NYASH_LLVM_DEBUG_PHI - NYASH_LLVM_TRACE_PHI → NYASH_LLVM_DEBUG_PHI_TRACE - NYASH_LLVM_VMAP_TRACE → NYASH_LLVM_DEBUG_PHI_TRACE 3. 後方互換性対応 - 旧環境変数使用時に非推奨警告表示 - Phase 278 で削除予定 【効果】 - ✅ ユーザビリティ向上: 覚える変数 8個→3個(62%削減) - ✅ 保守性向上: 環境変数チェック 30+箇所→1箇所(SSOT) - ✅ ドキュメント簡潔化: environment-variables.md 整理 - ✅ SSOT原則適用: debug_helper.py に環境変数ロジック集約 【影響範囲】 - 新規: debug_helper.py (SSOT) - 修正: 9ファイル(PHI関連Python) - ドキュメント: environment-variables.md, 10-Now.md 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2025-12-22 13:57:33 +09:00
## 今後の予定
1. **Phase 277 P0**: PHI型推論ドキュメント整備
2. **Phase 277 P1**: PHI順序検証強化
3. **Phase 278**: 後方互換性削除
---
**Phase 277 P2 完了!** 次はP0/P1の計画策定へ。