rust/tests/mir-opt/inline/inline_diverging.h.Inline.p...

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

69 lines
1.6 KiB
Diff
Raw Normal View History

- // MIR for `h` before Inline
+ // MIR for `h` after Inline
fn h() -> () {
2023-06-06 21:47:00 +08: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: !;
+ let mut _5: &fn() -> ! {sleep};
+ let mut _7: !;
+ scope 2 {
2023-06-06 21:47:00 +08:00
+ debug a => _4;
+ let _6: !;
+ scope 3 {
2023-06-06 21:47:00 +08:00
+ debug b => _6;
+ }
+ }
+ }
bb0: {
2023-06-06 21:47:00 +08:00
StorageLive(_1);
2023-06-24 00:53:09 +08:00
- _1 = call_twice::<!, fn() -> ! {sleep}>(sleep) -> unwind continue;
2023-06-06 21:47:00 +08:00
+ StorageLive(_2);
+ _2 = sleep;
+ StorageLive(_6);
+ StorageLive(_4);
+ StorageLive(_3);
+ _3 = &_2;
+ _4 = <fn() -> ! {sleep} as Fn<()>>::call(move _3, const ()) -> [return: bb1, unwind: bb5];
+ }
+
+ bb1: {
+ StorageDead(_3);
+ StorageLive(_5);
+ _5 = &_2;
+ _6 = <fn() -> ! {sleep} as Fn<()>>::call(move _5, const ()) -> [return: bb2, unwind: bb4];
+ }
+
+ bb2: {
+ StorageDead(_5);
+ StorageLive(_7);
+ _7 = move _4;
+ _1 = (move _7, move _6);
+ StorageDead(_7);
+ StorageDead(_4);
+ drop(_2) -> [return: bb3, unwind continue];
+ }
+
+ bb3: {
+ unreachable;
+ }
+
+ bb4 (cleanup): {
2023-08-24 20:26:26 +08:00
+ drop(_4) -> [return: bb5, unwind terminate(cleanup)];
+ }
+
+ bb5 (cleanup): {
2023-08-24 20:26:26 +08:00
+ drop(_2) -> [return: bb6, unwind terminate(cleanup)];
+ }
+
+ bb6 (cleanup): {
+ resume;
}
}