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:
@ -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);
|
||||
|
||||
|
||||
Reference in New Issue
Block a user