rust/tests/mir-opt/inline/cycle.f.Inline.diff
2023-01-11 09:32:08 +00:00

44 lines
2.2 KiB
Diff

- // MIR for `f` before Inline
+ // MIR for `f` after Inline
fn f(_1: impl Fn()) -> () {
debug g => _1; // in scope 0 at $DIR/cycle.rs:+0:6: +0:7
let mut _0: (); // return place in scope 0 at $DIR/cycle.rs:+0:20: +0:20
let _2: (); // in scope 0 at $DIR/cycle.rs:+1:5: +1:8
let mut _3: &impl Fn(); // in scope 0 at $DIR/cycle.rs:+1:5: +1:6
let mut _4: (); // in scope 0 at $DIR/cycle.rs:+1:5: +1:8
bb0: {
StorageLive(_2); // scope 0 at $DIR/cycle.rs:+1:5: +1:8
StorageLive(_3); // scope 0 at $DIR/cycle.rs:+1:5: +1:6
_3 = &_1; // scope 0 at $DIR/cycle.rs:+1:5: +1:6
StorageLive(_4); // scope 0 at $DIR/cycle.rs:+1:5: +1:8
Deinit(_4); // scope 0 at $DIR/cycle.rs:+1:5: +1:8
_2 = <impl Fn() as Fn<()>>::call(move _3, move _4) -> [return: bb1, unwind: bb3]; // scope 0 at $DIR/cycle.rs:+1:5: +1:8
// mir::Constant
// + span: $DIR/cycle.rs:6:5: 6:6
// + literal: Const { ty: for<'a> extern "rust-call" fn(&'a impl Fn(), ()) -> <impl Fn() as FnOnce<()>>::Output {<impl Fn() as Fn<()>>::call}, val: Value(<ZST>) }
}
bb1: {
StorageDead(_4); // scope 0 at $DIR/cycle.rs:+1:7: +1:8
StorageDead(_3); // scope 0 at $DIR/cycle.rs:+1:7: +1:8
StorageDead(_2); // scope 0 at $DIR/cycle.rs:+1:8: +1:9
_0 = const (); // scope 0 at $DIR/cycle.rs:+0:20: +2:2
drop(_1) -> [return: bb2, unwind: bb4]; // scope 0 at $DIR/cycle.rs:+2:1: +2:2
}
bb2: {
return; // scope 0 at $DIR/cycle.rs:+2:2: +2:2
}
bb3 (cleanup): {
drop(_1) -> bb4; // scope 0 at $DIR/cycle.rs:+2:1: +2:2
}
bb4 (cleanup): {
resume; // scope 0 at $DIR/cycle.rs:+0:1: +2:2
}
}