rust/tests/mir-opt/pre-codegen/optimizes_into_variable.main.ScalarReplacementOfAggregates.64bit.panic-abort.diff
2024-08-18 16:07:33 -07:00

71 lines
1.9 KiB
Diff

- // MIR for `main` before ScalarReplacementOfAggregates
+ // MIR for `main` after ScalarReplacementOfAggregates
fn main() -> () {
let mut _0: ();
let _1: i32;
let mut _2: (i32, bool);
let mut _4: [i32; 6];
let _5: usize;
let mut _6: usize;
let mut _7: bool;
let mut _9: Point;
+ let mut _10: u32;
+ let mut _11: u32;
scope 1 {
debug x => _1;
let _3: i32;
scope 2 {
debug y => _3;
let _8: u32;
scope 3 {
debug z => _8;
}
}
}
bb0: {
StorageLive(_1);
_2 = AddWithOverflow(const 2_i32, const 2_i32);
assert(!move (_2.1: bool), "attempt to compute `{} + {}`, which would overflow", const 2_i32, const 2_i32) -> [success: bb1, unwind unreachable];
}
bb1: {
_1 = move (_2.0: i32);
StorageLive(_3);
StorageLive(_4);
_4 = [const 0_i32, const 1_i32, const 2_i32, const 3_i32, const 4_i32, const 5_i32];
StorageLive(_5);
_5 = const 3_usize;
_6 = const 6_usize;
_7 = Lt(copy _5, copy _6);
assert(move _7, "index out of bounds: the length is {} but the index is {}", move _6, copy _5) -> [success: bb2, unwind unreachable];
}
bb2: {
_3 = copy _4[_5];
StorageDead(_5);
StorageDead(_4);
StorageLive(_8);
- StorageLive(_9);
- _9 = Point { x: const 12_u32, y: const 42_u32 };
- _8 = copy (_9.1: u32);
- StorageDead(_9);
+ StorageLive(_10);
+ StorageLive(_11);
+ nop;
+ _10 = const 12_u32;
+ _11 = const 42_u32;
+ nop;
+ _8 = copy _11;
+ StorageDead(_10);
+ StorageDead(_11);
+ nop;
StorageDead(_8);
StorageDead(_3);
StorageDead(_1);
return;
}
}