nyash-codex
5e3dec99e3
feat(joinir): Phase 171-172 Issue 4 - LoopScopeShapeBuilder unified initialization
Eliminates 50-60 lines of duplicated LoopScopeShape initialization across all 4 patterns.
**Changes**:
- New: `loop_scope_shape_builder.rs` with factory methods
- `empty_body_locals()`: For Pattern 1, 3 (condition-only analysis)
- `with_body_locals()`: For Pattern 2, 4 (AST-based body variable extraction)
- Updated all 4 patterns to use unified builder
- Includes unit tests for both factory methods
**Impact**:
- Pattern 1: 11 lines → 6 lines (5-line reduction)
- Pattern 2: 18 lines → 8 lines (10-line reduction)
- Pattern 3: 11 lines → 6 lines (5-line reduction)
- Pattern 4: 18 lines → 8 lines (10-line reduction)
- Total: 58 lines → 28 lines (30-line reduction, ~52%)
**Test**:
- cargo build --release: ✅ PASS
- cargo test --release: ✅ 720/800 PASS (same as before)
- Unit tests: ✅ 3/3 PASS
Phase 171-172 Stage 1: 25-30% deletion target (30 lines achieved)