summaryrefslogtreecommitdiffstats
path: root/tests/mir-opt/generator_storage_dead_unwind.main-{closure#0}.StateTransform.before.panic-ab...
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-30 03:57:31 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-30 03:57:31 +0000
commitdc0db358abe19481e475e10c32149b53370f1a1c (patch)
treeab8ce99c4b255ce46f99ef402c27916055b899ee /tests/mir-opt/generator_storage_dead_unwind.main-{closure#0}.StateTransform.before.panic-abort.mir
parentReleasing progress-linux version 1.71.1+dfsg1-2~progress7.99u1. (diff)
downloadrustc-dc0db358abe19481e475e10c32149b53370f1a1c.tar.xz
rustc-dc0db358abe19481e475e10c32149b53370f1a1c.zip
Merging upstream version 1.72.1+dfsg1.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'tests/mir-opt/generator_storage_dead_unwind.main-{closure#0}.StateTransform.before.panic-abort.mir')
-rw-r--r--tests/mir-opt/generator_storage_dead_unwind.main-{closure#0}.StateTransform.before.panic-abort.mir83
1 files changed, 83 insertions, 0 deletions
diff --git a/tests/mir-opt/generator_storage_dead_unwind.main-{closure#0}.StateTransform.before.panic-abort.mir b/tests/mir-opt/generator_storage_dead_unwind.main-{closure#0}.StateTransform.before.panic-abort.mir
new file mode 100644
index 000000000..25c656b3a
--- /dev/null
+++ b/tests/mir-opt/generator_storage_dead_unwind.main-{closure#0}.StateTransform.before.panic-abort.mir
@@ -0,0 +1,83 @@
+// MIR for `main::{closure#0}` before StateTransform
+
+fn main::{closure#0}(_1: [generator@$DIR/generator_storage_dead_unwind.rs:22:16: 22:18], _2: ()) -> ()
+yields ()
+ {
+ let mut _0: ();
+ let _3: Foo;
+ let _5: ();
+ let mut _6: ();
+ let _7: ();
+ let mut _8: Foo;
+ let _9: ();
+ let mut _10: Bar;
+ scope 1 {
+ debug a => _3;
+ let _4: Bar;
+ scope 2 {
+ debug b => _4;
+ }
+ }
+
+ bb0: {
+ StorageLive(_3);
+ _3 = Foo(const 5_i32);
+ StorageLive(_4);
+ _4 = Bar(const 6_i32);
+ StorageLive(_5);
+ StorageLive(_6);
+ _6 = ();
+ _5 = yield(move _6) -> [resume: bb1, drop: bb6];
+ }
+
+ bb1: {
+ StorageDead(_6);
+ StorageDead(_5);
+ StorageLive(_7);
+ StorageLive(_8);
+ _8 = move _3;
+ _7 = take::<Foo>(move _8) -> [return: bb2, unwind unreachable];
+ }
+
+ bb2: {
+ StorageDead(_8);
+ StorageDead(_7);
+ StorageLive(_9);
+ StorageLive(_10);
+ _10 = move _4;
+ _9 = take::<Bar>(move _10) -> [return: bb3, unwind unreachable];
+ }
+
+ bb3: {
+ StorageDead(_10);
+ StorageDead(_9);
+ _0 = const ();
+ StorageDead(_4);
+ goto -> bb4;
+ }
+
+ bb4: {
+ StorageDead(_3);
+ drop(_1) -> [return: bb5, unwind unreachable];
+ }
+
+ bb5: {
+ return;
+ }
+
+ bb6: {
+ StorageDead(_6);
+ StorageDead(_5);
+ StorageDead(_4);
+ drop(_3) -> [return: bb7, unwind unreachable];
+ }
+
+ bb7: {
+ StorageDead(_3);
+ drop(_1) -> [return: bb8, unwind unreachable];
+ }
+
+ bb8: {
+ generator_drop;
+ }
+}