rust/tests/mir-opt/inline/inline_coroutine.main.Inline.panic-unwind.diff

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

125 lines
3.4 KiB
Diff
Raw Normal View History

2020-11-11 00:00:00 +00:00
- // MIR for `main` before Inline
+ // MIR for `main` after Inline
fn main() -> () {
2023-06-06 09:47:00 -04:00
let mut _0: ();
2023-10-19 16:06:43 +00:00
let _1: std::ops::CoroutineState<i32, bool>;
2023-10-20 18:15:32 -07:00
let mut _2: std::pin::Pin<&mut {coroutine@$DIR/inline_coroutine.rs:19:5: 19:8}>;
let mut _3: &mut {coroutine@$DIR/inline_coroutine.rs:19:5: 19:8};
let mut _4: {coroutine@$DIR/inline_coroutine.rs:19:5: 19:8};
2023-10-03 13:19:00 +03:00
+ let mut _5: bool;
2020-11-11 00:00:00 +00:00
scope 1 {
2023-06-06 09:47:00 -04:00
debug _r => _1;
2020-11-11 00:00:00 +00:00
}
2023-06-06 09:47:00 -04:00
+ scope 2 (inlined g) {
2020-11-11 00:00:00 +00:00
+ }
2023-10-20 18:15:32 -07:00
+ scope 3 (inlined Pin::<&mut {coroutine@$DIR/inline_coroutine.rs:19:5: 19:8}>::new) {
2023-06-06 09:47:00 -04:00
+ debug pointer => _3;
2020-11-11 00:00:00 +00:00
+ scope 4 {
2023-10-20 18:15:32 -07:00
+ scope 5 (inlined Pin::<&mut {coroutine@$DIR/inline_coroutine.rs:19:5: 19:8}>::new_unchecked) {
2023-06-06 09:47:00 -04:00
+ debug pointer => _3;
2020-11-11 00:00:00 +00:00
+ }
+ }
+ }
2023-06-06 09:47:00 -04:00
+ scope 6 (inlined g::{closure#0}) {
2023-10-03 13:19:00 +03:00
+ debug a => _5;
2023-10-20 18:15:32 -07:00
+ let mut _6: &mut {coroutine@$DIR/inline_coroutine.rs:19:5: 19:8};
2023-10-03 13:19:00 +03:00
+ let mut _7: u32;
+ let mut _8: i32;
2020-11-11 00:00:00 +00:00
+ }
bb0: {
2023-06-06 09:47:00 -04:00
StorageLive(_1);
StorageLive(_2);
StorageLive(_3);
StorageLive(_4);
2023-06-23 17:53:09 +01:00
- _4 = g() -> [return: bb1, unwind continue];
2020-11-11 00:00:00 +00:00
- }
-
- bb1: {
2023-10-20 18:15:32 -07:00
+ _4 = {coroutine@$DIR/inline_coroutine.rs:19:5: 19:8 (#0)};
2023-06-06 09:47:00 -04:00
_3 = &mut _4;
2023-10-20 18:15:32 -07:00
- _2 = Pin::<&mut {coroutine@$DIR/inline_coroutine.rs:19:5: 19:8}>::new(move _3) -> [return: bb2, unwind: bb5];
2020-11-11 00:00:00 +00:00
- }
-
- bb2: {
2023-10-20 18:15:32 -07:00
+ _2 = Pin::<&mut {coroutine@$DIR/inline_coroutine.rs:19:5: 19:8}> { pointer: move _3 };
2023-06-06 09:47:00 -04:00
StorageDead(_3);
2023-10-20 18:15:32 -07:00
- _1 = <{coroutine@$DIR/inline_coroutine.rs:19:5: 19:8} as Coroutine<bool>>::resume(move _2, const false) -> [return: bb3, unwind: bb5];
2023-10-03 13:19:00 +03:00
+ StorageLive(_5);
+ _5 = const false;
2023-09-30 13:44:31 +03:00
+ StorageLive(_6);
2023-10-04 17:50:03 +00:00
+ StorageLive(_7);
2023-10-20 18:15:32 -07:00
+ _6 = (_2.0: &mut {coroutine@$DIR/inline_coroutine.rs:19:5: 19:8});
2023-10-03 13:19:00 +03:00
+ _7 = discriminant((*_6));
+ switchInt(move _7) -> [0: bb5, 1: bb9, 3: bb10, otherwise: bb11];
2020-11-11 00:00:00 +00:00
}
- bb3: {
+ bb1: {
2023-10-04 17:50:03 +00:00
+ StorageDead(_7);
+ StorageDead(_6);
2023-10-03 13:19:00 +03:00
+ StorageDead(_5);
2023-06-06 09:47:00 -04:00
StorageDead(_2);
2023-01-28 18:49:48 +00:00
- drop(_4) -> [return: bb4, unwind: bb6];
+ drop(_4) -> [return: bb2, unwind: bb4];
}
- bb4: {
+ bb2: {
2023-06-06 09:47:00 -04:00
StorageDead(_4);
_0 = const ();
StorageDead(_1);
return;
2020-11-11 00:00:00 +00:00
}
2023-01-28 18:49:48 +00:00
- bb5 (cleanup): {
- drop(_4) -> [return: bb6, unwind terminate(cleanup)];
+ bb3 (cleanup): {
+ drop(_4) -> [return: bb4, unwind terminate(cleanup)];
}
- bb6 (cleanup): {
+ bb4 (cleanup): {
2023-06-06 09:47:00 -04:00
resume;
2020-11-11 00:00:00 +00:00
+ }
+
2023-01-28 18:49:48 +00:00
+ bb5: {
2023-10-03 13:19:00 +03:00
+ StorageLive(_8);
+ switchInt(_5) -> [0: bb6, otherwise: bb7];
2020-11-11 00:00:00 +00:00
+ }
+
2023-01-28 18:49:48 +00:00
+ bb6: {
2023-10-03 13:19:00 +03:00
+ _8 = const 13_i32;
2023-01-28 18:49:48 +00:00
+ goto -> bb8;
2020-11-11 00:00:00 +00:00
+ }
+
2023-01-28 18:49:48 +00:00
+ bb7: {
2023-10-03 13:19:00 +03:00
+ _8 = const 7_i32;
2023-01-28 18:49:48 +00:00
+ goto -> bb8;
2020-11-11 00:00:00 +00:00
+ }
+
2023-01-28 18:49:48 +00:00
+ bb8: {
2023-10-19 16:06:43 +00:00
+ _1 = CoroutineState::<i32, bool>::Yielded(move _8);
2023-10-03 13:19:00 +03:00
+ discriminant((*_6)) = 3;
2023-06-06 09:47:00 -04:00
+ goto -> bb1;
2020-11-11 00:00:00 +00:00
+ }
+
2023-01-28 18:49:48 +00:00
+ bb9: {
2023-10-19 21:46:28 +00:00
+ assert(const false, "coroutine resumed after completion") -> [success: bb9, unwind: bb3];
+ }
+
2023-01-28 18:49:48 +00:00
+ bb10: {
2023-10-03 13:19:00 +03:00
+ StorageLive(_8);
+ StorageDead(_8);
2023-10-19 16:06:43 +00:00
+ _1 = CoroutineState::<i32, bool>::Complete(_5);
2023-10-03 13:19:00 +03:00
+ discriminant((*_6)) = 1;
2023-06-06 09:47:00 -04:00
+ goto -> bb1;
2020-11-11 00:00:00 +00:00
+ }
+
2023-01-28 18:49:48 +00:00
+ bb11: {
2023-06-06 09:47:00 -04:00
+ unreachable;
2020-11-11 00:00:00 +00:00
}
}