|
| 1 | +- // MIR for `main` before PreCodegen |
| 2 | ++ // MIR for `main` after PreCodegen |
| 3 | + |
| 4 | + fn main() -> () { |
| 5 | + let mut _0: (); // return place in scope 0 at $DIR/issue-73223.rs:+0:11: +0:11 |
| 6 | + let _1: i32; // in scope 0 at $DIR/issue-73223.rs:+1:9: +1:14 |
| 7 | + let mut _2: std::option::Option<i32>; // in scope 0 at $DIR/issue-73223.rs:+1:23: +1:30 |
| 8 | + let _3: i32; // in scope 0 at $DIR/issue-73223.rs:+2:14: +2:15 |
| 9 | + let mut _5: (&i32, &i32); // in scope 0 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 10 | + let mut _6: &i32; // in scope 0 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 11 | + let mut _7: &i32; // in scope 0 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 12 | + let mut _10: bool; // in scope 0 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 13 | + let mut _11: bool; // in scope 0 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 14 | + let mut _12: i32; // in scope 0 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 15 | + let _14: !; // in scope 0 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 16 | + let mut _15: &i32; // in scope 0 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 17 | + let _16: &i32; // in scope 0 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 18 | + let mut _17: &i32; // in scope 0 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 19 | + let _18: &i32; // in scope 0 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 20 | + let mut _19: std::option::Option<std::fmt::Arguments>; // in scope 0 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 21 | + scope 1 { |
| 22 | + debug split => _1; // in scope 1 at $DIR/issue-73223.rs:+1:9: +1:14 |
| 23 | + let _4: std::option::Option<i32>; // in scope 1 at $DIR/issue-73223.rs:+6:9: +6:14 |
| 24 | + scope 3 { |
| 25 | + debug _prev => _4; // in scope 3 at $DIR/issue-73223.rs:+6:9: +6:14 |
| 26 | + let _8: &i32; // in scope 3 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 27 | + let _9: &i32; // in scope 3 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 28 | + let mut _20: &i32; // in scope 3 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 29 | + scope 4 { |
| 30 | + debug left_val => _8; // in scope 4 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 31 | + debug right_val => _9; // in scope 4 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 32 | + let _13: core::panicking::AssertKind; // in scope 4 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 33 | + scope 5 { |
| 34 | + debug kind => _13; // in scope 5 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 35 | + } |
| 36 | + } |
| 37 | + } |
| 38 | + } |
| 39 | + scope 2 { |
| 40 | + debug v => _3; // in scope 2 at $DIR/issue-73223.rs:+2:14: +2:15 |
| 41 | + } |
| 42 | + |
| 43 | + bb0: { |
| 44 | + StorageLive(_1); // scope 0 at $DIR/issue-73223.rs:+1:9: +1:14 |
| 45 | + StorageLive(_2); // scope 0 at $DIR/issue-73223.rs:+1:23: +1:30 |
| 46 | + Deinit(_2); // scope 0 at $DIR/issue-73223.rs:+1:23: +1:30 |
| 47 | + ((_2 as Some).0: i32) = const 1_i32; // scope 0 at $DIR/issue-73223.rs:+1:23: +1:30 |
| 48 | + discriminant(_2) = 1; // scope 0 at $DIR/issue-73223.rs:+1:23: +1:30 |
| 49 | + StorageLive(_3); // scope 0 at $DIR/issue-73223.rs:+2:14: +2:15 |
| 50 | + _3 = ((_2 as Some).0: i32); // scope 0 at $DIR/issue-73223.rs:+2:14: +2:15 |
| 51 | + _1 = _3; // scope 2 at $DIR/issue-73223.rs:+2:20: +2:21 |
| 52 | + StorageDead(_3); // scope 0 at $DIR/issue-73223.rs:+2:20: +2:21 |
| 53 | + StorageDead(_2); // scope 0 at $DIR/issue-73223.rs:+4:6: +4:7 |
| 54 | + StorageLive(_4); // scope 1 at $DIR/issue-73223.rs:+6:9: +6:14 |
| 55 | + StorageLive(_5); // scope 3 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 56 | + StorageLive(_6); // scope 3 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 57 | + _6 = &_1; // scope 3 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 58 | + StorageLive(_7); // scope 3 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 59 | + _20 = const _; // scope 3 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 60 | + // mir::Constant |
| 61 | + // + span: $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 62 | + // + literal: Const { ty: &i32, val: Unevaluated(main, [], Some(promoted[0])) } |
| 63 | + _7 = _20; // scope 3 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 64 | + Deinit(_5); // scope 3 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 65 | + (_5.0: &i32) = move _6; // scope 3 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 66 | + (_5.1: &i32) = move _7; // scope 3 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 67 | + StorageDead(_7); // scope 3 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 68 | + StorageDead(_6); // scope 3 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 69 | + StorageLive(_8); // scope 3 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 70 | + _8 = (_5.0: &i32); // scope 3 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 71 | + StorageLive(_9); // scope 3 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 72 | + _9 = (_5.1: &i32); // scope 3 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 73 | + StorageLive(_10); // scope 4 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 74 | + StorageLive(_11); // scope 4 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 75 | + StorageLive(_12); // scope 4 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 76 | + _12 = (*_8); // scope 4 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 77 | + _11 = Eq(move _12, const 1_i32); // scope 4 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 78 | + StorageDead(_12); // scope 4 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 79 | + _10 = Not(move _11); // scope 4 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 80 | + StorageDead(_11); // scope 4 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 81 | + switchInt(move _10) -> [false: bb2, otherwise: bb1]; // scope 4 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 82 | + } |
| 83 | + |
| 84 | + bb1: { |
| 85 | + StorageLive(_13); // scope 4 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 86 | + StorageLive(_14); // scope 5 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 87 | + StorageLive(_15); // scope 5 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 88 | + StorageLive(_16); // scope 5 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 89 | + _16 = _8; // scope 5 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 90 | + _15 = _16; // scope 5 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 91 | + StorageLive(_17); // scope 5 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 92 | + StorageLive(_18); // scope 5 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 93 | + _18 = _9; // scope 5 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 94 | + _17 = _18; // scope 5 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 95 | + StorageLive(_19); // scope 5 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 96 | + Deinit(_19); // scope 5 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 97 | + discriminant(_19) = 0; // scope 5 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 98 | + _14 = core::panicking::assert_failed::<i32, i32>(const core::panicking::AssertKind::Eq, move _15, move _17, move _19); // scope 5 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 99 | + // mir::Constant |
| 100 | + // + span: $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 101 | + // + literal: Const { ty: for<'r, 's, 't0> fn(core::panicking::AssertKind, &'r i32, &'s i32, Option<Arguments<'t0>>) -> ! {core::panicking::assert_failed::<i32, i32>}, val: Value(<ZST>) } |
| 102 | + // mir::Constant |
| 103 | + // + span: $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 104 | + // + literal: Const { ty: core::panicking::AssertKind, val: Value(Scalar(0x00)) } |
| 105 | + } |
| 106 | + |
| 107 | + bb2: { |
| 108 | + StorageDead(_10); // scope 4 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 109 | + StorageDead(_9); // scope 3 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 110 | + StorageDead(_8); // scope 3 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 111 | + StorageDead(_5); // scope 3 at $SRC_DIR/core/src/macros/mod.rs:LL:COL |
| 112 | + StorageDead(_4); // scope 1 at $DIR/issue-73223.rs:+8:1: +8:2 |
| 113 | + StorageDead(_1); // scope 0 at $DIR/issue-73223.rs:+8:1: +8:2 |
| 114 | + return; // scope 0 at $DIR/issue-73223.rs:+8:2: +8:2 |
| 115 | + } |
| 116 | + } |
| 117 | + |
0 commit comments