rust/tests/mir-opt/inline/inline_diverging.h.Inline.panic-abort.diff

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

52 lines
1.3 KiB
Diff
Raw Normal View History

- // MIR for `h` before Inline
+ // MIR for `h` after Inline
fn h() -> () {
2023-06-06 08:47:00 -05:00
let mut _0: ();
let _1: (!, !);
+ let mut _2: fn() -> ! {sleep};
+ scope 1 (inlined call_twice::<!, fn() -> ! {sleep}>) {
+ debug f => _2;
+ let mut _3: &fn() -> ! {sleep};
+ let _4: !;
2023-06-06 08:47:00 -05:00
+ let mut _5: &fn() -> ! {sleep};
+ scope 2 {
2023-06-06 08:47:00 -05:00
+ debug a => _4;
+ let _6: !;
+ scope 3 {
2023-06-06 08:47:00 -05:00
+ debug b => _6;
+ }
+ }
+ }
bb0: {
2023-06-06 08:47:00 -05:00
StorageLive(_1);
- _1 = call_twice::<!, fn() -> ! {sleep}>(sleep) -> unwind unreachable;
+ StorageLive(_2);
+ _2 = sleep;
+ StorageLive(_4);
+ StorageLive(_6);
+ StorageLive(_3);
+ _3 = &_2;
+ _4 = <fn() -> ! {sleep} as Fn<()>>::call(move _3, const ()) -> [return: bb1, unwind unreachable];
+ }
+
+ bb1: {
+ StorageDead(_3);
+ StorageLive(_5);
+ _5 = &_2;
+ _6 = <fn() -> ! {sleep} as Fn<()>>::call(move _5, const ()) -> [return: bb2, unwind unreachable];
+ }
+
+ bb2: {
+ StorageDead(_5);
+ _1 = (_4, _6);
+ drop(_2) -> [return: bb3, unwind unreachable];
+ }
+
+ bb3: {
+ unreachable;
}
}