feat(mir): Phase 63-6-1/2 MIR Phi type_hint field & JoinIR propagation

Phase 63-6-1: MirInstruction::Phi に type_hint フィールド追加
- Added `type_hint: Option<MirType>` field to Phi instruction
- Updated 21 files with type_hint initialization (all set to None for legacy paths)
- Pattern matching updated across codebase (11 files)
- Test code updated (basic_block.rs)

Phase 63-6-2: JoinIR→MIR Bridge で型ヒント伝播実装
- Modified convert.rs: Select → MIR now creates PHI with type_hint
- Removed Copy instructions from then/else blocks
- PHI instruction at merge block receives type_hint from JoinIR Select
- Test verification:  Type hint propagation successful (Some(Integer))

Modified files:
- instruction.rs: Added type_hint field definition
- join_ir_vm_bridge/convert.rs: Select lowering with PHI + type_hint
- 19 other files: type_hint field initialization

Test results:
-  test_type_hint_propagation_simple: Type hint = Some(Integer) confirmed
-  7/8 if_select tests passing (1 race condition, passes individually)

Next: Phase 63-6-3 (lifecycle.rs で型ヒント使用)

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

Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
nyash-codex
2025-11-30 04:35:40 +09:00
parent 360ad48d93
commit c6edbaaf3a
21 changed files with 55 additions and 33 deletions

View File

@ -324,7 +324,7 @@ impl BasicBlock {
incoming: (BasicBlockId, ValueId),
) -> Result<(), String> {
for inst in &mut self.instructions {
if let MirInstruction::Phi { dst, inputs } = inst {
if let MirInstruction::Phi { dst, inputs, .. } = inst {
if *dst == phi_dst {
inputs.push(incoming);
return Ok(());
@ -580,6 +580,7 @@ mod tests {
let phi_inst = MirInstruction::Phi {
dst: ValueId::new(0),
inputs: vec![(BasicBlockId::new(1), ValueId::new(1))],
type_hint: None, // Phase 63-6: Test code, no type hint
};
bb.add_instruction(phi_inst);