|
| 1 | +- // MIR for `bar` before Inline |
| 2 | ++ // MIR for `bar` after Inline |
| 3 | + |
| 4 | + fn bar(_1: P) -> () { |
| 5 | + debug _baz => _1; // in scope 0 at $DIR/issue-78442.rs:9:5: 9:9 |
| 6 | + let mut _0: (); // return place in scope 0 at $DIR/issue-78442.rs:10:3: 10:3 |
| 7 | + let _2: (); // in scope 0 at $DIR/issue-78442.rs:11:5: 11:17 |
| 8 | + let mut _3: &fn() {foo}; // in scope 0 at $DIR/issue-78442.rs:11:5: 11:15 |
| 9 | + let _4: fn() {foo}; // in scope 0 at $DIR/issue-78442.rs:11:5: 11:15 |
| 10 | + let mut _5: (); // in scope 0 at $DIR/issue-78442.rs:11:5: 11:17 |
| 11 | ++ scope 1 (inlined <fn() {foo} as Fn<()>>::call - shim(fn() {foo})) { // at $DIR/issue-78442.rs:11:5: 11:17 |
| 12 | ++ } |
| 13 | + |
| 14 | + bb0: { |
| 15 | + StorageLive(_2); // scope 0 at $DIR/issue-78442.rs:11:5: 11:17 |
| 16 | + StorageLive(_3); // scope 0 at $DIR/issue-78442.rs:11:5: 11:15 |
| 17 | + StorageLive(_4); // scope 0 at $DIR/issue-78442.rs:11:5: 11:15 |
| 18 | +- _4 = hide_foo() -> [return: bb1, unwind: bb4]; // scope 0 at $DIR/issue-78442.rs:11:5: 11:15 |
| 19 | ++ _4 = hide_foo() -> [return: bb1, unwind: bb3]; // scope 0 at $DIR/issue-78442.rs:11:5: 11:15 |
| 20 | + // mir::Constant |
| 21 | + // + span: $DIR/issue-78442.rs:11:5: 11:13 |
| 22 | + // + literal: Const { ty: fn() -> impl std::ops::Fn<()> {hide_foo}, val: Value(Scalar(<ZST>)) } |
| 23 | + } |
| 24 | + |
| 25 | + bb1: { |
| 26 | + _3 = &_4; // scope 0 at $DIR/issue-78442.rs:11:5: 11:15 |
| 27 | + StorageLive(_5); // scope 0 at $DIR/issue-78442.rs:11:5: 11:17 |
| 28 | +- _2 = <impl Fn<()> as Fn<()>>::call(move _3, move _5) -> [return: bb2, unwind: bb4]; // scope 0 at $DIR/issue-78442.rs:11:5: 11:17 |
| 29 | +- // mir::Constant |
| 30 | +- // + span: $DIR/issue-78442.rs:11:5: 11:15 |
| 31 | +- // + literal: Const { ty: for<'r> extern "rust-call" fn(&'r impl std::ops::Fn<()>, ()) -> <impl std::ops::Fn<()> as std::ops::FnOnce<()>>::Output {<impl std::ops::Fn<()> as std::ops::Fn<()>>::call}, val: Value(Scalar(<ZST>)) } |
| 32 | ++ _2 = move (*_3)() -> [return: bb5, unwind: bb3]; // scope 1 at $DIR/issue-78442.rs:11:5: 11:17 |
| 33 | + } |
| 34 | + |
| 35 | + bb2: { |
| 36 | +- StorageDead(_5); // scope 0 at $DIR/issue-78442.rs:11:16: 11:17 |
| 37 | +- StorageDead(_3); // scope 0 at $DIR/issue-78442.rs:11:16: 11:17 |
| 38 | +- StorageDead(_4); // scope 0 at $DIR/issue-78442.rs:11:17: 11:18 |
| 39 | +- StorageDead(_2); // scope 0 at $DIR/issue-78442.rs:11:17: 11:18 |
| 40 | +- _0 = const (); // scope 0 at $DIR/issue-78442.rs:10:3: 12:2 |
| 41 | +- drop(_1) -> [return: bb3, unwind: bb5]; // scope 0 at $DIR/issue-78442.rs:12:1: 12:2 |
| 42 | ++ return; // scope 0 at $DIR/issue-78442.rs:12:2: 12:2 |
| 43 | + } |
| 44 | + |
| 45 | +- bb3: { |
| 46 | +- return; // scope 0 at $DIR/issue-78442.rs:12:2: 12:2 |
| 47 | ++ bb3 (cleanup): { |
| 48 | ++ drop(_1) -> bb4; // scope 0 at $DIR/issue-78442.rs:12:1: 12:2 |
| 49 | + } |
| 50 | + |
| 51 | + bb4 (cleanup): { |
| 52 | +- drop(_1) -> bb5; // scope 0 at $DIR/issue-78442.rs:12:1: 12:2 |
| 53 | ++ resume; // scope 0 at $DIR/issue-78442.rs:7:1: 12:2 |
| 54 | + } |
| 55 | + |
| 56 | +- bb5 (cleanup): { |
| 57 | +- resume; // scope 0 at $DIR/issue-78442.rs:7:1: 12:2 |
| 58 | ++ bb5: { |
| 59 | ++ StorageDead(_5); // scope 0 at $DIR/issue-78442.rs:11:16: 11:17 |
| 60 | ++ StorageDead(_3); // scope 0 at $DIR/issue-78442.rs:11:16: 11:17 |
| 61 | ++ StorageDead(_4); // scope 0 at $DIR/issue-78442.rs:11:17: 11:18 |
| 62 | ++ StorageDead(_2); // scope 0 at $DIR/issue-78442.rs:11:17: 11:18 |
| 63 | ++ _0 = const (); // scope 0 at $DIR/issue-78442.rs:10:3: 12:2 |
| 64 | ++ drop(_1) -> [return: bb2, unwind: bb4]; // scope 0 at $DIR/issue-78442.rs:12:1: 12:2 |
| 65 | + } |
| 66 | + } |
| 67 | + |
0 commit comments