- // 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 continue]; } 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 continue]; } 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; } }