Commit Graph

1796 Commits

Author SHA1 Message Date
4bff4ecf43 feat(joinir): Phase 190-impl NumberAccumulation pattern implementation
Phase 190 implementation: Detect and emit number accumulation patterns
like `result = result * 10 + digit` in Pattern 2 loops.

## Changes

### Task 190-impl-1: UpdateRhs enum extension
- Added `NumberAccumulation { base, digit_var }` variant to UpdateRhs
- Implemented detection logic in `analyze_update_value()`:
  - Detects pattern: `(carrier * base) + digit`
  - Supports both Add and Subtract operations
  - Base must be integer constant, digit must be variable
- Added 3 unit tests (base10, base2, wrong_lhs cases)

### Task 190-impl-2: Pattern2/4 whitelist update
- Updated `check_carrier_updates_allowed()` in common_init.rs
- NumberAccumulation now allowed in can_lower()
- Pattern 4 (continue) rejects with passthrough (not yet implemented)

### Task 190-impl-3: Carrier update emission
- Implemented NumberAccumulation emission in carrier_update_emitter.rs
- Emits 3 instructions:
  1. Const(base)
  2. BinOp(Mul, carrier, base) → tmp
  3. BinOp(Add/Sub, tmp, digit) → result
- Added 2 unit tests (base10 emission, digit_not_found error)
- Both UpdateEnv and ConditionEnv versions supported

### Task 190-impl-4: E2E tests (in progress)
- Created phase190_atoi_impl.hako (Pattern 2 with break)
- Created phase190_parse_number_impl.hako (Pattern 2 with break)
- Tests compile and use Pattern 2 correctly
- Runtime execution validation pending

## Files Modified
- loop_update_analyzer.rs (+180 lines: enum, detection, 3 tests)
- carrier_update_emitter.rs (+182 lines: emission, 2 tests)
- common_init.rs (+4 lines: whitelist update)
- loop_with_continue_minimal.rs (+16 lines: Pattern 4 passthrough)

## Test Results
-  All analyzer unit tests pass (4/4)
-  All emitter unit tests pass (12/12)
- 🔄 E2E runtime validation in progress

## Architecture Notes
- **Box-first modular design**: Single responsibility per function
- **Fail-fast**: Complex patterns rejected early in can_lower()
- **Pattern 2 only**: Pattern 1/3 don't support carriers yet
- **Pattern 4 future**: Passthrough stub for continue support

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

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2025-12-09 02:14:57 +09:00
0b705f9ca0 docs(joinir): Phase 190 NumberAccumulation design (doc-only)
Design document for `result = result * 10 + digit` patterns:

- Section 1-2: Target loop analysis (_atoi, _parse_number)
- Section 3: UpdateKind::NumberAccumulation { base: i64 }
- Section 4: classify_number_update() algorithm
- Section 5: Pattern2/4 can_lower() specification
- Section 6: CarrierUpdateLowerer 2-instruction emission
- Section 7-12: Implementation roadmap, testing strategy

Key decisions:
- Safe: lhs = lhs * CONST + Variable/Const
- Unsafe: LHS 2+ occurrences, variable base, method calls
- Integer type only (no string)
- Fail-Fast for Complex patterns

Next: Phase 190-impl for code implementation

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

Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-09 01:54:53 +09:00
88e9fff141 docs(joinir): Phase 189 JsonParser mini verification
Investigation Results:
- _match_literal:  Works correctly (Pattern1)
- _parse_number:  Blocked by LoopBodyLocal
- _atoi:  Carrier detection gap identified

Root Cause: Carrier Detection Limitation
- Pattern1/2 only detect loop counter from condition
- Accumulator variables (result = result * 10 + digit) not detected
- MIR shows missing PHI for accumulator variables

Phase 188 Status:
- StringAppend implementation:  Complete and correct
- End-to-end verification:  Waiting for carrier detection fix

Phase 190 Options:
- Option A: Expand LoopUpdateAnalyzer (recursive traversal)
- Option B: Explicit carrier annotation syntax
- Option C: Whole-body variable analysis

Created:
- phase189-jsonparser-mini-verification.md (comprehensive report)
- 3 test files (parse_number, atoi, match_literal)

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

Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-09 01:47:07 +09:00
d4e099978c refactor(joinir): Extract common carrier update validation to reduce Pattern2/4 duplication
## Summary

- **130 lines of duplicate code eliminated** (66 from Pattern2 + 64 from Pattern4)
- **40 lines net reduction** (130 duplicates - 90 new common code)
- **New utility function**: `CommonPatternInitializer::check_carrier_updates_allowed()`

## Changes

### Added
- `common_init.rs`: New `check_carrier_updates_allowed()` function (90 lines)
  - Validates carrier updates allow only simple expressions (Const, Variable, StringLiteral)
  - Rejects complex expressions (method calls, nested BinOp)
  - Shared by Pattern2 and Pattern4

### Refactored
- `pattern2_with_break.rs`: Simplified `can_lower()` (-66 lines)
  - Removed 60-line duplicate carrier validation logic
  - Now calls `CommonPatternInitializer::check_carrier_updates_allowed()`

- `pattern4_with_continue.rs`: Simplified `can_lower()` (-64 lines)
  - Removed 60-line duplicate carrier validation logic
  - Now calls `CommonPatternInitializer::check_carrier_updates_allowed()`

## Benefits

1. **Single source of truth**: All Pattern2/4 carrier validation uses same logic
2. **Maintainability**: Updates to carrier validation only need to happen once
3. **Consistency**: Uniform error messages and validation behavior
4. **Testability**: Common function can be tested independently

## Tests

 All tests passing (788 passed, 0 failed, 64 ignored)

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

Co-Authored-By: Claude Haiku 4.5 <noreply@anthropic.com>
2025-12-09 01:25:22 +09:00
a2933880ae feat(joinir): Phase 188 StringAppend support in Pattern2/4
- Extended Pattern2/4 whitelist to accept StringLiteral updates
- CarrierUpdateEmitter now emits JoinIR for string append
- Selective Fail-Fast: accept safe patterns, reject complex

Changes:
- pattern2_with_break.rs: StringLiteral whitelist
- pattern4_with_continue.rs: StringLiteral whitelist
- carrier_update_emitter.rs: StringLiteral JoinIR emission

Tests:
- phase188_string_append_char.hako
- phase188_string_append_literal.hako
- 10/10 carrier_update_emitter tests PASS

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

Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-09 01:09:54 +09:00
d4231f5d3a feat(joinir): Phase 185-187 body-local infrastructure + string design
Phase 185: Body-local Pattern2/4 integration skeleton
- Added collect_body_local_variables() helper
- Integrated UpdateEnv usage in loop_with_break_minimal
- Test files created (blocked by init lowering)

Phase 186: Body-local init lowering infrastructure
- Created LoopBodyLocalInitLowerer box (378 lines)
- Supports BinOp (+/-/*//) + Const + Variable
- Fail-Fast for method calls/string operations
- 3 unit tests passing

Phase 187: String UpdateLowering design (doc-only)
- Defined UpdateKind whitelist (6 categories)
- StringAppendChar/Literal patterns identified
- 3-layer architecture documented
- No code changes

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

Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-09 00:59:38 +09:00
b6e31cf8ca feat(joinir): Phase 184 - Body-local MIR Lowering Infrastructure
Phase 184 implements the foundation for body-local variable support in
update expressions, completing the three-box architecture:
LoopBodyLocalEnv (storage), UpdateEnv (composition), and
CarrierUpdateEmitter (emission).

## Implementation Summary

### Task 184-1: Design Document
- Created phase184-body-local-mir-lowering.md
- Two-Environment System design (ConditionEnv + LoopBodyLocalEnv)
- Box-First design principles documented

### Task 184-2: LoopBodyLocalEnv Implementation
- New file: src/mir/join_ir/lowering/loop_body_local_env.rs (216 lines)
- Storage box for body-local variable name → ValueId mappings
- BTreeMap for deterministic ordering (PHI consistency)
- 7 unit tests: empty env, single/multiple locals, get/contains, iteration

### Task 184-3: UpdateEnv Implementation
- New file: src/mir/join_ir/lowering/update_env.rs (237 lines)
- Composition box for unified variable resolution
- Priority order: ConditionEnv (condition vars) → LoopBodyLocalEnv (body-local)
- 8 unit tests: priority, fallback, not found, combined lookup

### Task 184-4: CarrierUpdateEmitter Integration
- Modified: src/mir/join_ir/lowering/carrier_update_emitter.rs
- Added emit_carrier_update_with_env() (UpdateEnv version)
- Kept emit_carrier_update() for backward compatibility
- 4 new unit tests: body-local variable, priority, not found, const update
- Total 10 tests PASS (6 existing + 4 new)

### Task 184-5: Representative Test Cases
- apps/tests/phase184_body_local_update.hako (Pattern1 baseline)
- apps/tests/phase184_body_local_with_break.hako (Pattern2, Phase 185 target)

### Task 184-6: Documentation Updates
- Updated: docs/development/current/main/joinir-architecture-overview.md
- Updated: CURRENT_TASK.md (Phase 184 completion record)

## Test Results

All 25 unit tests PASS:
- LoopBodyLocalEnv: 7 tests
- UpdateEnv: 8 tests
- CarrierUpdateEmitter: 10 tests (6 existing + 4 new)

Build:  Success (0 errors)

## Design Constraints

Following 箱理論 (Box Theory) principles:
- Single Responsibility: Each box has one clear purpose
- Deterministic: BTreeMap ensures consistent ordering
- Conservative: Pattern5 (Trim) integration deferred to Phase 185
- Fail-Fast: Explicit errors for unsupported patterns

## Scope Limitation

Phase 184 provides the **infrastructure only**:
-  Storage box (LoopBodyLocalEnv)
-  Composition box (UpdateEnv)
-  Emission support (CarrierUpdateEmitter)
-  Pattern2/4 integration (requires body-local collection, Phase 185)

## Next Steps

Phase 185: Pattern2/4 Integration
- Integrate LoopBodyLocalEnv into Pattern2/4 lowerers
- Add body-local variable collection from loop body AST
- Enable full E2E body-local variable support in update expressions

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

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2025-12-08 23:59:19 +09:00
440f8646b1 feat(joinir): Phase 183 LoopBodyLocal role separation + test fixes
Phase 183 Implementation:
- Added is_var_used_in_condition() helper for AST variable detection
- Implemented LoopBodyLocal filtering in TrimLoopLowerer
- Created 4 test files for P1/P2 patterns
- Added 5 unit tests for variable detection

Test Fixes:
- Fixed test_is_outer_scope_variable_pinned (BasicBlockId import)
- Fixed test_pattern2_accepts_loop_param_only (literal node usage)

Refactoring:
- Unified pattern detection documentation
- Consolidated CarrierInfo initialization
- Documented LoopScopeShape construction paths

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

Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-08 23:43:26 +09:00
a3df5ecc7a feat(joinir): Phase 183 LoopBodyLocal role separation
Implements role-based separation of LoopBodyLocal variables to prevent
inappropriate Trim promotion for body-only local variables.

## Changes

### Task 183-1: Design Documentation
- Created `phase183-loopbodylocal-role-separation.md` with role taxonomy:
  - Condition LoopBodyLocal: Used in loop conditions → Trim promotion target
  - Body-only LoopBodyLocal: Only in body → No promotion needed
- Documented architectural approach and implementation strategy

### Task 183-2: Implementation
- Added `TrimLoopLowerer::is_var_used_in_condition()` helper
  - Recursively checks if variable appears in condition AST
  - Handles BinaryOp, UnaryOp, MethodCall node types
- Updated `try_lower_trim_like_loop()` to filter condition LoopBodyLocal
  - Only processes LoopBodyLocal that appear in break conditions
  - Skips body-only LoopBodyLocal (returns Ok(None) early)
- Added 5 unit tests for variable detection logic

### Task 183-3: Test Files
- Created `phase183_body_only_loopbodylocal.hako`
  - Demonstrates body-only LoopBodyLocal (`temp`) not triggering Trim
  - Verified trace output: "No LoopBodyLocal detected, skipping Trim lowering"
- Created additional test files (phase183_p1_match_literal, phase183_p2_atoi, phase183_p2_parse_number)

### Task 183-4: Documentation Updates
- Updated `joinir-architecture-overview.md` with Phase 183 results
- Updated `CURRENT_TASK.md` with Phase 183 completion status

## Results

 LoopBodyLocal role separation complete
 Body-only LoopBodyLocal skips Trim promotion
 5 unit tests passing
 Trace verification successful

## Next Steps (Phase 184+)

- Body-local variable MIR lowering support
- String concatenation filter relaxation
- Full _parse_number/_atoi implementation

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

Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2025-12-08 23:14:10 +09:00
94bf00faf9 refactor(joinir): Phase 183-3 Document LoopScopeShape construction paths
Clarifies that LoopScopeShape has two complementary construction paths
for different contexts (AST-based vs LoopForm-based).

## Analysis

After investigating, discovered these builders serve **different purposes**:

1. **AST-based** (`patterns/loop_scope_shape_builder.rs`):
   - Builds from AST during MIR generation
   - Extracts body_locals from ASTNode::Local declarations
   - Used in Pattern 1-4 lowerers

2. **LoopForm-based** (`loop_scope_shape/builder.rs`):
   - Builds from LoopForm during JoinIR lowering
   - Analyzes LoopFormIntake snapshots
   - Used in generic_case_a and pattern routing

These are NOT duplicates - they're complementary paths!

## Changes

1. **Cross-Reference Documentation**:
   - `patterns/loop_scope_shape_builder.rs`: Added Phase 183-3 section
   - `loop_scope_shape/builder.rs`: Added Phase 183-3 section
   - Both now reference each other for clarity

2. **LoopScopeShape Struct Documentation**:
   - Added "Phase 183-3: Construction Paths" section
   - Documents two construction paths and their contexts
   - Explains when to use each builder

3. **Clarified Responsibilities**:
   - AST-based: For MIR building phase
   - LoopForm-based: For JoinIR lowering phase
   - Both maintain consistent field initialization

## Benefits

- **Clear separation**: Documented different contexts for each builder
- **Maintainability**: Future developers understand which builder to use
- **No code changes**: Pure documentation improvement
- **Cross-references**: Easy navigation between related modules

## Testing

 All loop_scope_shape tests pass (24 tests)
 No behavioral changes
 Documentation-only refactoring

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

Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2025-12-08 22:22:25 +09:00
a32791b0ed refactor(joinir): Phase 183-2 Consolidate CarrierInfo initialization
Makes CarrierInfo::from_variable_map() the primary initialization method.
Common pattern initializer now delegates to this centralized logic.

## Changes

1. **Primary Method: CarrierInfo::from_variable_map()**:
   - Now the single source of truth for CarrierInfo construction
   - Used by both MIR and JoinIR contexts
   - Documented as primary initialization method (Phase 183-2)

2. **CommonPatternInitializer Refactoring**:
   - Converted to thin wrapper around `CarrierInfo::from_variable_map()`
   - Delegates carrier collection to primary method
   - Only adds pattern-specific exclusion filtering
   - Reduced code duplication (~30 lines removed)

3. **Documentation Updates**:
   - `carrier_info.rs`: Added Phase 183-2 section explaining primary role
   - `common_init.rs`: Documented delegation strategy
   - Clear separation of concerns between modules

4. **Removed Duplicate Logic**:
   - Eliminated manual carrier collection in `common_init.rs`
   - Removed `CarrierVar` import (no longer directly constructed)
   - Unified sorting and validation in one place

## Benefits

- **Single source of truth**: CarrierInfo construction logic in one module
- **Consistency**: Same initialization algorithm across MIR/JoinIR
- **Maintainability**: Changes to carrier logic only needed once
- **Testability**: Primary logic tested in carrier_info module

## Testing

 All carrier_info tests pass (7 tests)
 All pattern tests pass (124 tests)
 No behavioral changes

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

Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2025-12-08 22:19:41 +09:00
3ece6896c4 refactor(joinir): Phase 183-1 Unify pattern detection in loop_pattern_detection
Consolidates duplicate pattern detection logic across two routing layers.

## Changes

1. **Unified Detection Documentation**:
   - Added Phase 183 comments to `loop_pattern_detection::classify()`
   - Documented that this is the single source of truth for pattern classification
   - Both routers now reference this centralized function

2. **Router Documentation Updates**:
   - `patterns/router.rs`: Added Phase 183 comments explaining structure-based routing
   - `loop_pattern_router.rs`: Added unified detection section
   - Both routers now explicitly reference shared detection logic

3. **Improved Debug Output**:
   - Added `pattern_kind` to debug message in `route_loop_pattern()`
   - Helps diagnose pattern matching failures

## Benefits

- **Single source of truth**: Pattern classification logic in one place
- **Consistency**: Both routers use same detection algorithm
- **Maintainability**: Changes to classification rules only needed once
- **Documentation**: Clear references between routers and detection module

## Testing

 All loop_pattern_detection tests pass
 Pattern 2 tests pass
 No behavioral changes, pure documentation/organization refactoring

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

Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2025-12-08 22:17:06 +09:00
174a647413 docs(joinir): Phase 182 final completion report
Phase 182 PARTIAL SUCCESS Summary:
 Pattern1/Pattern2 routing and execution verified
 Representative tests created (2/2 PASS)
 Blockers identified with clear remediation paths

Achievements:
- Design document created (phase182-simple-loops-design.md)
- Routing whitelist updated (+3 JsonParser methods)
- Pattern routing verified with structure-only tracing
- 2 representative tests created and passing:
  * phase182_p1_match_literal.hako (Pattern1 Simple)
  * phase182_p2_break_integer.hako (Pattern2 Break)
- Documentation updated (architecture + CURRENT_TASK)

Blockers Identified:
1. LoopBodyLocal variable handling
   - Current: Trim-specific carrier promotion (fails for normal loops)
   - Needed: Role-based distinction (condition vs body-only locals)
   - Impact: Blocks _parse_number, _atoi, most JsonParser loops

2. String concatenation filter (Phase 178)
   - Current: Conservative rejection of string ops
   - Needed: Gradual enablement for JsonParser use cases
   - Impact: Blocks loops with string building

Next Steps (Phase 183):
- Minimal fix for LoopBodyLocal handling
- String concat enablement with safety checks
- Full _parse_number/_atoi implementation

Commits: 4 total (5d99c31c, be063658, d5b63e09, 0772dc3e)
Build:  All successful
Tests:  2/2 PASS
2025-12-08 21:42:51 +09:00
0772dc3e82 docs(joinir): Phase 182-6 Update documentation with P1/P2 verification results
Phase 182 Summary:
 Pattern1 (Simple) verification complete
 Pattern2 (Break) verification complete with integer operations
 Routing whitelist updated (_parse_number/2, _atoi/1, _match_literal/3)
 Representative tests created and passing

Blockers identified:
1. LoopBodyLocal variable handling
   - Current: Tries Trim-specific carrier promotion (fails)
   - Needed: Allow pure local variables (no promotion) in P1/P2
2. String concatenation filter (Phase 178)
   - Current: Rejects 'num_str = num_str + ch' conservatively
   - Needed: Gradual enablement for JsonParser use cases

Updated documentation:
- joinir-architecture-overview.md: Added Phase 182 status to JsonParser section
- CURRENT_TASK.md: Added Phase 182 completion and Phase 183 next steps
- phase182-simple-loops-design.md: Design memo for Phase 182
2025-12-08 21:41:19 +09:00
d5b63e0944 test(joinir): Phase 182-5 Add P1/P2 pattern verification tests
Phase 182-5 Test Results:
 Pattern1 (Simple) - phase182_p1_match_literal.hako PASSES
 Pattern2 (Break) - phase182_p2_break_integer.hako PASSES

Verification:
- P1 routes correctly to Pattern1_Minimal
- P2 routes correctly to Pattern2_WithBreak
- Both execute successfully with integer operations
- _match_literal logic verified (string matching with early return)

Blockers for actual JsonParser loops (_parse_number, _atoi):
1. LoopBodyLocal variables (ch, digit_pos, pos) trigger promotion requirement
   - Current system only handles Trim-specific carrier promotion
   - P2 should allow purely local temp variables (not promoted to carriers)
2. String operation filter (Phase 178)
   - Conservatively rejects string concat: num_str = num_str + ch
   - Need gradual enablement for JsonParser use cases

Next steps (Phase 182-6):
- Document blockers and workaround strategies
- Recommend LoopBodyLocal handling improvements for Phase 183+
2025-12-08 21:39:49 +09:00
be06365870 feat(joinir): Phase 182-2 Add _parse_number/_atoi to routing whitelist
- Add JsonParserBox._parse_number/2 (P2 Break pattern)
- Add JsonParserBox._atoi/1 (P2 Break pattern)
- Fix _match_literal arity: /2 -> /3 (s, pos, literal)
- Prepare for Phase 182 simple loop implementation
2025-12-08 21:36:39 +09:00
5d99c31cdc docs(joinir): Add Phase 182 simple loops design memo 2025-12-08 21:34:16 +09:00
17ecb0ed26 docs(joinir): Add Phase 182+183 design documents
Phase 182: CharComparison generalization plan
- Generalize "Trim" pattern to "CharComparison" pattern
- Documentation/comment updates only (no code changes)
- Prepare for JsonParser quote/delimiter/escape patterns
- Phase 183+: Type/file renaming with backward compatibility

Phase 183: Selfhost Depth-2 JoinIR re-observation plan
- Re-examine 5-7 loops in selfhost depth-2 (compiler compiling itself)
- Observe JoinIR pattern usage (P1-P5) after Phase 171-181 improvements
- Design .hako-side JoinIR frontend for Phase 184+ implementation
- Create 3 analysis documents: loop inventory, observation, plan

Related: Phase 150 (depth-1), Phase 171-181 (JoinIR improvements)

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

Co-Authored-By: Claude Haiku 4.5 <noreply@anthropic.com>
2025-12-08 21:26:57 +09:00
6e429624eb docs(joinir): Update CURRENT_TASK for Phase 181 completion 2025-12-08 21:20:38 +09:00
6dddb40245 docs(joinir): Add Phase 181 JsonParser loop roadmap 2025-12-08 21:19:54 +09:00
bd282d3ddd docs(joinir): Phase 180 completion - Trim/P5 submodule refactoring
Phase 180-5: Update documentation and finalize

Changes:
- joinir-architecture-overview.md: Added TrimLoopLowerer section
- phase180-trim-module-design.md: Pattern4 analysis and timeline update
- CURRENT_TASK.md: Added Phase 180 completion entry

Summary:
- Task 180-1: Design document 
- Task 180-2: TrimLoopLowerer skeleton 
- Task 180-3: Pattern2 refactoring  (-135 lines)
- Task 180-4: Pattern4 analysis (skipped - detection only)
- Task 180-5: Documentation update 

Impact:
- Pattern2: 510 → 375 lines (-26%)
- TrimLoopLowerer: 404 lines (new dedicated module)
- Code organization: Single responsibility, high reusability
- Behavior: 100% preserved, refactoring only
- Build: SUCCESS (0 errors)
2025-12-08 21:09:00 +09:00
b6ed6295a3 refactor(joinir): Move Trim logic from Pattern2 to TrimLoopLowerer
Phase 180-3: Extract Pattern2 Trim/P5 logic to dedicated module

Changes:
- Pattern2: Delegated Trim processing to TrimLoopLowerer (~160 lines removed)
- Pattern2: Simplified to ~25 lines of delegation code
- TrimLoopLowerer: Implemented full logic from Pattern2 (lines 180-340)
- Net reduction: -135 lines in Pattern2 (371 lines total)

Implementation:
- LoopConditionScopeBox + LoopBodyCarrierPromoter integration
- Carrier initialization code generation (substring + whitespace check)
- Trim break condition replacement (!is_carrier)
- ConditionEnv bindings setup (carrier + original variable)

Testing:
- cargo build --release: SUCCESS (0 errors, warnings only)
- All existing Pattern2 tests: PASS
- No behavior changes, refactoring only
2025-12-08 21:07:39 +09:00
2bbee79adf feat(joinir): Add TrimLoopLowerer skeleton for P5 module
Phase 180-2: Create dedicated Trim/CharComparison lowering module

- New module: src/mir/join_ir/lowering/trim_loop_lowering.rs
- TrimLoopLowerer::try_lower_trim_like_loop() skeleton
- Integrates LoopConditionScopeBox + LoopBodyCarrierPromoter
- Returns TrimLoweringResult with updated condition/carrier/bindings
- TODO: Phase 180-3 will implement full logic from Pattern2
2025-12-08 21:02:13 +09:00
28512b4bb4 docs(joinir): Add Phase 180 Trim module design 2025-12-08 20:59:31 +09:00
eb946797f3 docs(joinir): Update architecture docs for Phase 179-B completion
Phase 179-B Task 7: Document PatternPipelineContext in architecture
overview and record completion in CURRENT_TASK.md.

Changes:
- joinir-architecture-overview.md: Add PatternPipelineContext section
  - Document "解析済みコンテキスト箱" design philosophy
  - Explain analyzer-only dependencies and pattern-specific variants
  - Add design principles (Pure analysis container, Option<T> patterns, SSOT)
- CURRENT_TASK.md: Add Phase 179-B completion summary
  - Record all 7 tasks and their outcomes
  - Document line reduction: P1/P3 11%, P2 1.5%, P4 1.9%
  - Note design constraints for Pattern 2/4 complexity

Test Results:
- Pattern 1 (loop_min_while.hako):  PASS
- Pattern 2 (joinir_min_loop.hako):  PASS
- Pattern 3 (loop_if_phi.hako):  PASS (sum=9)
- Pattern 4 (loop_continue_pattern4.hako):  PASS (25)

All representative test cases pass with identical behavior.

🤖 Generated with Claude Code (https://claude.com/claude-code)

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2025-12-08 19:51:04 +09:00
4a27b6cd3f refactor(joinir): Unify Pattern 4 with PatternPipelineContext
Phase 179-B Task 6: Refactor Pattern 4 to use PatternPipelineContext
for unified preprocessing.

Changes:
- Use build_pattern_context() for initial loop variable extraction and scope construction
- Extract loop_var_name, loop_var_id, carrier_info_prelim, and scope from context
- Keep Pattern4CarrierAnalyzer logic inline (Select-based continue semantics)
- Reduce line count: 422 → 414 lines (1.9% reduction)

Note:
Pattern 4 has complex carrier analysis (Select-based continue, carrier filtering,
normalization) that requires specialized Pattern4CarrierAnalyzer. The minimal
refactoring maintains this complexity while establishing the pipeline pattern.

Benefits:
- Consistent entry point with Patterns 1-3
- Unified preprocessing flow
- Maintains all existing functionality and test compatibility

🤖 Generated with Claude Code (https://claude.com/claude-code)

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2025-12-08 19:49:50 +09:00
b25fc289eb refactor(joinir): Unify Pattern 2 with PatternPipelineContext
Phase 179-B Task 5: Refactor Pattern 2 to use PatternPipelineContext
for unified preprocessing.

Changes:
- Use build_pattern_context() for initial loop variable extraction and scope construction
- Extract loop_var_name, loop_var_id, carrier_info, and scope from context
- Keep Trim pattern logic inline (complex, needs dedicated module in future Phase 180+)
- Reduce line count: 517 → 509 lines (1.5% reduction)

Note:
Pattern 2 has significant complexity (Trim pattern, carrier filtering, break
condition processing) that cannot be easily unified without breaking the
"analyzer-only" design constraint of PatternPipelineContext. The minimal
refactoring maintains compatibility while establishing the pipeline pattern.

Benefits:
- Consistent entry point with Pattern 1/3
- Establishes pattern for future Trim module extraction
- Maintains all existing functionality and test compatibility

🤖 Generated with Claude Code (https://claude.com/claude-code)

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2025-12-08 19:47:29 +09:00
94f992f574 refactor(joinir): Unify Pattern 3 with PatternPipelineContext
Phase 179-B Task 4: Refactor Pattern 3 to use PatternPipelineContext
for unified preprocessing.

Changes:
- Use build_pattern_context() for loop variable extraction and scope construction
- Extract sum_var_id from ctx.carrier_info instead of direct initialization
- Reduce line count: 168 → 149 lines (11% reduction, lower than target due to already optimized code)
- Maintain exact same behavior and test compatibility

Benefits:
- Consistent preprocessing logic with Pattern 1
- Single source of truth for carrier analysis
- Cleaner separation of concerns (analysis vs lowering)

🤖 Generated with Claude Code (https://claude.com/claude-code)

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2025-12-08 19:44:45 +09:00
48ef94e9ba refactor(joinir): Unify Pattern 1 with PatternPipelineContext
- Reduced preprocessing from 61 lines to ~30 lines (51% reduction)
- Total file size: 139 → 118 lines (15% reduction)
- Uses build_pattern_context() for unified initialization
- All tests passing (loop_min_while.hako verified)
2025-12-08 19:34:31 +09:00
3b6b2027a1 feat(joinir): Add PatternPipelineContext for unified preprocessing 2025-12-08 19:32:04 +09:00
83aca8c08e docs(joinir): Add Phase 179-B Generic Pattern Framework design 2025-12-08 19:29:10 +09:00
739ad7fbe7 chore: Remove unused imports (Task 4)
Task 4: Additional dead code and unused imports cleanup
- Removed 7 unused imports across 6 files:
  - conversion_pipeline.rs: MirModule
  - pattern1_minimal.rs: BTreeMap
  - pattern2_with_break.rs: BTreeMap
  - pattern3_with_if_phi.rs: BTreeMap
  - pattern4_with_continue.rs: CarrierInfo, BTreeMap
  - condition_var_analyzer.rs: BasicBlockId
- Build verified: 0 unused import warnings remaining
- Warning count reduced: 70 → 63 warnings

Result: Cleaner code, reduced compiler warnings
2025-12-08 19:22:57 +09:00
10fc2718e5 refactor(joinir): Restrict visibility of internal lowering modules (Task 3)
Task 3: Unused public exports visibility restriction
- Changed 15 modules from 'pub mod' to 'pub(crate) mod'
- Modules changed: bool_expr_lowerer, carrier_update_emitter, common,
  condition_lowerer, condition_var_extractor, exit_args_resolver,
  generic_case_a, if_lowering_router, if_select, loop_form_intake,
  loop_pattern_router, loop_pattern_validator, loop_patterns,
  loop_view_builder, value_id_ranges
- All changed modules have 0 external uses outside src/mir/join_ir/lowering/
- Kept public re-exports for functions that need backward compatibility
- Build verified: cargo build --release passes with 0 errors

Result: Improved API encapsulation without breaking external users
2025-12-08 19:19:58 +09:00
6d0b4e3bfd refactor(joinir): Document loop pattern detection architecture (Task 2)
Task 2: Loop pattern detection structure investigation
- Analyzed src/mir/loop_pattern_detection/ (~3k lines, not 26k as expected)
- Module is already well-structured with Phase 194+ architecture
- Legacy functions (Phase 188) are still actively used, not truly deprecated
- Added clarifying comment to prevent future confusion about "legacy" label

Decision: Skip reorganization - current structure is clean and functional.
No subdirectory needed for active production code.
2025-12-08 19:17:34 +09:00
1193b8b66d refactor(joinir): Document condition lowerer architecture (Task 1)
Task 1: Condition lowerer integration investigation
- Analyzed 3 modules: condition_lowerer (522L), bool_expr_lowerer (371L), condition_env_builder (248L)
- Key finding: Cannot merge safely due to different design patterns:
  - condition_lowerer: JoinIR-based (pure functional, no builder state)
  - bool_expr_lowerer: MIR-based (stateful MirBuilder)
- Added clear TODO comment documenting the distinction
- bool_expr_lowerer appears unused (all tests commented), candidate for future removal

Decision: Keep separate, document architecture clearly for future maintainers
2025-12-08 19:15:22 +09:00
17b9201f96 refactor(joinir): Unify exit binding generation using ExitMetaCollector
Phase 179 Task 2: Modular exit binding generation

Changes:
- Pattern 4 (pattern4_with_continue.rs):
  - REPLACED: Manual exit_bindings loop (28 lines deleted)
  - WITH: ExitMetaCollector::collect() call (10 lines added)
  - ADDED: Validation that all carriers have bindings
  - Net reduction: 10 lines, improved modularity

- Pattern 3 (pattern3_with_if_phi.rs):
  - DOCUMENTED: Why hardcoded ValueId(18) exists
  - ADDED: TODO with migration path to ExitMeta-based approach
  - DEFERRED: Actual migration (requires lowerer return type change)
  - Impact: Low priority - Pattern 3 is test-only

Benefits:
- Unified approach: Pattern 4 now uses same ExitMetaCollector as other patterns
- Reusability: ExitMetaCollector is pattern-agnostic Box
- Maintainability: Less duplicate code, clearer responsibilities
- Testability: ExitMetaCollector has independent unit tests

Notes:
- Pattern 3 migration deferred (lowerer doesn't return ExitMeta yet)
- Comprehensive TODO comment documents migration path
- Pre-existing test failure (stage1_usingresolver) unrelated to this change
2025-12-08 19:09:06 +09:00
0dc9b838d6 refactor(joinir): Extract carrier_update_emitter from loop_with_break_minimal
Phase 179 Task 1: Modular separation for single responsibility

Changes:
- NEW: carrier_update_emitter.rs (416 lines)
  - emit_carrier_update() function + 6 unit tests
  - Focused module for UpdateExpr → JoinInst conversion
- REDUCED: loop_with_break_minimal.rs (998→597 lines, -401 lines)
  - Removed emit_carrier_update() and carrier_update_tests module
  - Now imports from carrier_update_emitter
- UPDATED: mod.rs - added carrier_update_emitter module

Benefits:
- Single responsibility: carrier update emission isolated
- Reusability: can be used by Pattern 3, 4, and future patterns
- Testability: independent unit tests
- Maintainability: 40% size reduction in loop_with_break_minimal.rs

Note: Pre-existing test failure in test_pattern2_accepts_loop_param_only
is unrelated to this refactoring (test expects 1 var but gets 3 due to
literal "10" and "5" being counted as variables).
2025-12-08 19:03:30 +09:00
4e7f7f1334 fix(tools): Add log forwarding to hakorune_emit_mir.sh provider path 2025-12-08 18:57:05 +09:00
1e51c2c521 chore(joinir): Clarify TODO comment in exit_binding.rs
Phase 179-A Step 4: Update TODO comment to be more specific about
the future improvement path (using MirBuilder's next_value_id()).

Changed vague "TODO: This should be delegated to a proper ValueId allocator"
to clear "Future improvement: Delegate to MirBuilder's next_value_id()".

Note: Other TODOs in loop_patterns/mod.rs are placeholder tests waiting
for future implementation and are intentionally kept as-is.
2025-12-08 18:41:01 +09:00
4cbe412c22 refactor(joinir): Replace magic numbers with named constants
Phase 179-A Step 3: Improve code maintainability by replacing hardcoded
magic values with descriptive named constants.

Changes:
- instruction_rewriter.rs: K_EXIT_FUNC_NAME constant for "join_func_2"
- pattern3_with_if_phi.rs: PATTERN3_K_EXIT_SUM_FINAL_ID for ValueId(18)

Benefits:
- Self-documenting code (names explain the meaning)
- Easier to maintain (change in one place)
- Prevents typos and inconsistencies
2025-12-08 18:38:30 +09:00
95f3aa429e refactor(joinir): Extract legacy binding path to routing_legacy_binding.rs
Phase 179-A Step 2: Separate LoopFrontendBinding JSON construction logic
into dedicated module for better organization.

Changes:
- New file: routing_legacy_binding.rs (223 lines)
- routing.rs: cf_loop_joinir_impl() simplified to 15 lines (delegates to legacy path)
- Routing now clearly separates pattern-based vs. legacy binding paths

Benefits:
- Clear separation of concerns (pattern router vs. legacy whitelist)
- routing.rs reduced from 364 to 146 lines (60% reduction)
- Legacy path isolated for future deprecation
2025-12-08 18:36:13 +09:00
7a01ffe522 fix(joinir): Phase 177-3 ValueId collision fix for multi-carrier loops
Root cause: JoinIR ValueId collision between function parameters and condition bindings
- Same ValueId used for both `result_init` (carrier param) and `limit` (condition var)
- Phase 33-21 was overwriting condition bindings when remapping carrier PHIs

Fix implemented (Option B - immediate protection):
1. Phase 177-3: Protect condition-only variables from Phase 33-21 override
   - Collect condition_bindings that are NOT carriers (by checking exit_bindings)
   - Skip remapping for these protected ValueIds
2. Phase 177-3-B: Handle body-only carriers explicitly
   - Carriers that appear in condition_bindings (added by Phase 176-5)
   - Map them to correct PHI dsts by name lookup

Investigation tools added:
- [DEBUG-177] trace logs for remapper state tracking
- Phase 177-3 protection logging
- BoundaryInjector PHI collision detection

Test results:
-  Integer multi-carrier test: Output 3 (expected)
- ⚠️ String test: RC=0 but empty output (separate issue - string concat emit)

Design docs created:
- phase177-parse-string-design.md: _parse_string loop analysis
- phase177-carrier-evolution.md: Carrier progression Phase 174-179

Next: Investigate string concatenation emit for full _parse_string support
2025-12-08 16:34:04 +09:00
99d329096f feat(joinir): Phase 176 Pattern2 multi-carrier lowering complete
Task 176-1: Pattern2 limitation investigation
- Identified 10 limitation points where only position carrier was handled
- Added TODO markers for Phase 176-2/3 implementation
- Created phase176-pattern2-limitations.md documentation

Task 176-2: CarrierUpdateLowerer helper implementation
- Implemented emit_carrier_update() helper function
- Supports CounterLike and AccumulationLike UpdateExpr patterns
- Added 6 unit tests (all passing)
- Fail-Fast error handling for carrier/variable not found

Task 176-3: Pattern2 lowerer multi-carrier extension
- Extended header PHI generation for all carriers
- Implemented loop update for all carriers using emit_carrier_update()
- Extended ExitLine/ExitMeta construction for all carriers
- Updated function call/jump args to include all carriers
- 9/10 tests passing (1 pre-existing test issue)

Task 176-4: E2E testing and bug fixes
- Fixed Trim pattern loop_var_name overwrite bug (pattern2_with_break.rs)
- Fixed InstructionRewriter latch_incoming mapping bug
- All E2E tests passing (RC=0): pos + result dual-carrier loops work
- test_jsonparser_parse_string_min2.hako verified

Task 176-5: Documentation updates
- Created phase176-completion-report.md
- Updated phase175-multicarrier-design.md with completion status
- Updated joinir-architecture-overview.md roadmap
- Updated CURRENT_TASK.md with Phase 176 completion + Phase 177 TODO
- Updated loop_pattern_space.md F-axis (multi-carrier support complete)

Technical achievements:
- Pattern2 now handles single/multiple carriers uniformly
- CarrierInfo architecture proven to work end-to-end
- Two critical bugs fixed (loop_var overwrite, latch_incoming mapping)
- No regressions in existing tests

Next: Phase 177 - Apply to JsonParser _parse_string full implementation
2025-12-08 15:17:53 +09:00
24aa8ced75 feat(joinir): Phase 175 - P5 multi-carrier architecture validation
Task 175-1: Analyzed _parse_string carrier candidates
- Identified 3 carriers: pos (position), result (buffer), is_ch_match (promoted)
- Categorized as: required carriers (pos, result), promoted carrier (is_ch_match)

Task 175-2: Validated existing boxes support multi-carrier
- CarrierInfo: Vec<CarrierData> supports arbitrary carriers 
- LoopUpdateAnalyzer: Loops over all carriers 
- ExitMeta: Vec<(String, ValueId)> supports all exit bindings 
- ExitLineReconnector: Reconnects all carriers to variable_map 
- No code changes needed - architecture already supports it!

Task 175-3: PoC test revealed Pattern2 limitation
- Test: test_jsonparser_parse_string_min2.hako (pos + result carriers)
- CarrierInfo detected 3 carriers correctly (pos, result, is_ch_match)
- variable_map contains all carriers at pattern2_start
- BUT: Pattern2's Trim optimization only emits pos carrier in MIR
- MIR shows result stays as empty string (no loop update emitted)
- Root cause: Trim pattern focuses on position-only optimization

Task 175-4: Documentation updates
- Created: phase175-multicarrier-design.md (comprehensive analysis)
- Updated: CURRENT_TASK.md (Phase 175 completion)
- Updated: routing.rs (added JsonParserStringTest2 whitelist)

Key Finding:
- Architecture is sound  - all boxes support multi-carrier
- Pattern2 implementation gap  - Trim optimization ignores non-position carriers
- Phase 176 scope: Extend Pattern2 to emit all carrier updates

Next: Phase 176 for escape sequence handling and full multi-carrier emission
2025-12-08 13:34:43 +09:00
309d0803c7 feat(joinir): Phase 174 - JsonParser complex loop P5 extension design
- Task 174-1: Complex loop inventory (_parse_string/_parse_array/_parse_object)
  - Analyzed remaining JsonParser loops for P5 expansion potential
  - Identified _parse_string as most Trim-like structure (99% similarity)
  - Documented complexity scores and minimization potential

- Task 174-2: Selected _parse_string as next P5 target (closest to Trim)
  - Reason: LoopBodyLocal 'ch' usage matches Trim pattern exactly
  - Structure: loop(pos < len) + substring + char comparison + break
  - Minimization: Remove escape/buffer/continue → identical to Trim

- Task 174-3: Design doc for P5B extension (TrimLoopHelper reuse strategy)
  - File: docs/development/current/main/phase174-jsonparser-p5b-design.md
  - Strategy: Reuse existing TrimLoopHelper without modifications
  - Proven: Pattern applies to any character comparison, not just whitespace

- Task 174-4: Minimal PoC (_parse_string without escape) successful
  - Test: local_tests/test_jsonparser_parse_string_min.hako
  - Result: [pattern2/trim] Safe Trim pattern detected 
  - Detection: Trim with literals=['"'] (quote instead of whitespace)
  - Routing: Added whitelist entries for JsonParserStringTest methods

- Task 174-5: Documentation updates
  - Updated CURRENT_TASK.md with Phase 174 summary
  - Updated joinir-architecture-overview.md with P5 generality proof
  - Created phase174-jsonparser-loop-inventory-2.md (detailed analysis)
  - Created phase174-jsonparser-p5b-design.md (implementation strategy)

Success Criteria Met:
 _parse_string minimized version runs on P5 pipeline
 TrimLoopHelper works with '"' (non-whitespace character)
 Proven: Trim pattern is character-comparison-generic, not whitespace-specific
 Two new design docs (inventory + design)
 Phase 175+ roadmap established (multi-carrier, escape sequences)

Technical Achievement:
The P5 Trim pipeline successfully handled a quote-detection loop with zero code changes,
proving the architecture's generality beyond whitespace trimming.
2025-12-08 13:08:44 +09:00
290e97c54c feat(joinir): Phase 173 - JsonParser P5 expansion with _skip_whitespace
- Task 173-1: JsonParser loop inventory recheck
  - Observed 6 loops: _trim (2 loops, already working), _skip_whitespace,
    _parse_string, _parse_array, _unescape_string
  - Created comprehensive observation report with Trim similarity ratings
  - Discovered that JsonParser._trim already uses P5 pipeline successfully

- Task 173-2: Selected _skip_whitespace as Trim-equivalent pattern
  - Perfect structural match with Trim (100% identical)
  - Independent helper method, easy to test
  - Frequently used in JsonParser (7 call sites)

- Task 173-3: Design doc for P5 pipeline extension to JsonParser
  - Confirmed existing TrimLoopHelper works without modification
  - No charAt() support needed (_skip_whitespace uses substring())
  - Documented data flow and risk analysis

- Task 173-4: Successfully converted _skip_whitespace to JoinIR
  - Created test case: local_tests/test_jsonparser_skip_whitespace.hako
  - Added routing whitelist: JsonParserTest._skip_whitespace/3
  - Pattern detection SUCCESS:
    * LoopBodyLocal 'ch' detected
    * Carrier promotion to 'is_ch_match'
    * Trim pattern recognized
    * JoinIR generation successful
  - Verified P5 pipeline works for both static box methods and helper methods

- Task 173-5: Documentation updates
  - phase173-jsonparser-loop-recheck.md: Loop observation report
  - phase173-jsonparser-p5-design.md: P5 extension design
  - phase173-jsonparser-p5-impl.md: Implementation results
  - CURRENT_TASK.md: Phase 173 completion record

Key achievement: Proven that Trim P5 pipeline is fully generic -
works for both TrimTest (static box method) and JsonParser (helper method).
LoopBodyLocal carrier promotion is production-ready for Trim-like patterns.

Changes:
- src/mir/builder/control_flow/joinir/routing.rs: Add JsonParserTest whitelist
- docs/development/current/main/*173*.md: 3 new documentation files
- CURRENT_TASK.md: Phase 173 completion entry
2025-12-08 10:13:34 +09:00
cbeab6abd7 feat(joinir): Phase 201 - JoinInlineBoundaryBuilder expansion to Pattern3/4
- Task 201-1: Established canonical Builder pattern documentation
  - Created docs/development/current/main/joinir-boundary-builder-pattern.md
  - Documented Builder usage patterns for all patterns (P1/P2/P3/P4)
  - Added reference comments in pattern lowerers

- Task 201-2: Refactored Pattern3 to use Builder (removed field mutations)
  - Replaced new_with_exit_bindings + field mutation with Builder chain
  - Pattern3: 2 carriers (i + sum), exit_bindings, loop_var_name
  - Proper LoopExitBinding struct usage

- Task 201-3: Refactored Pattern4 to use Builder (continue/Trim support)
  - Replaced new_with_exit_bindings + field mutation with Builder chain
  - Pattern4: Dynamic carrier count, proper boundary construction

- Task 201-4: Added unit tests for Pattern3/4 style boundaries
  - test_builder_pattern3_style: Two carriers, exit_bindings validation
  - test_builder_pattern4_style: Dynamic carrier count validation
  - Verified no field mutations remain (exit_binding.rs uses deprecated fields only)

- Task 201-5: Updated architecture docs and CURRENT_TASK
  - joinir-architecture-overview.md: Builder now applied to all patterns
  - CURRENT_TASK.md: Phase 201 completion entry

All patterns now use consistent boundary construction via Builder.
Tests: All patterns pass (挙動不変).
2025-12-08 06:14:03 +09:00
891c39c67f docs(joinir): Task 200-4 - Update CURRENT_TASK and overview for Phase 200 Pipeline Cleanup
- Added Phase 200 completion status to CURRENT_TASK.md
- Updated joinir-architecture-overview.md with:
  - JoinInlineBoundaryBuilder (Phase 200-2)
  - JoinIRVerifier (Phase 200-3)
- Phase 200 achievements:
  - Task 200-1: Pattern × Box matrix table (21 boxes documented)
  - Task 200-2: Builder pattern for JoinInlineBoundary (Pattern2 pilot)
  - Task 200-3: Debug contract verifier for LoopHeader PHI/ExitLine
  - Task 200-4: Documentation updates

Phase 200 cleanup focuses on pipeline structure improvement without
changing behavior, establishing foundation for future refactoring.
2025-12-08 04:35:13 +09:00
c63e6deb32 feat(joinir): Task 200-3 - JoinIRVerifier for LoopHeader PHI and ExitLine contracts
Debug-only verification module to catch JoinIR contract violations early:
- verify_loop_header_phis: Checks loop_var_name → PHI exists in header block
- verify_exit_line: Checks exit_bindings → values exist, exit block in range
- verify_joinir_contracts: Main entry point, runs all checks

Implementation:
- Added verification functions to merge/mod.rs (private module has type access)
- Called from merge_joinir_mir_blocks after exit block setup
- Only active in debug builds (#[cfg(debug_assertions)])

Benefits:
- Catches "动くけど header PHI 無い" bugs immediately
- Validates exit_bindings before variable_map reconnection
- Prevents silent contract violations during development
2025-12-08 04:33:33 +09:00
3645a3c2d2 feat(joinir): Task 200-2 - JoinInlineBoundaryBuilder implementation for Pattern2
Builder pattern for JoinInlineBoundary construction, reduces field manipulation scattering.

# Changes
- NEW: src/mir/join_ir/lowering/inline_boundary_builder.rs (165 lines)
  - JoinInlineBoundaryBuilder with 7 fluent methods
  - Complete unit test coverage (4 tests)
- MODIFIED: src/mir/join_ir/lowering/mod.rs (+2 lines)
  - Export inline_boundary_builder module
  - Public re-export of JoinInlineBoundaryBuilder
- MODIFIED: src/mir/builder/control_flow/joinir/patterns/pattern2_with_break.rs
  - Replace direct boundary field manipulation with builder pattern
  - 9 lines of field assignments → fluent builder chain

# Benefits
- **Centralized**: All boundary construction logic in builder
- **Readable**: Fluent API shows construction intent clearly
- **Maintainable**: Changes to boundary structure isolated to builder
- **Type Safe**: Builder validates field consistency

# Tests
 All builder unit tests pass (4/4)
 All pattern module tests pass (30+)
 Library build succeeds with no errors

🤖 Generated with Claude Code (https://claude.com/claude-code)

Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2025-12-08 04:25:58 +09:00