summaryrefslogtreecommitdiffstats
path: root/tests/mir-opt/generator_drop_cleanup.main-{closure#0}.generator_drop.0.panic-abort.mir
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_drop_cleanup.main-{closure#0}.generator_drop.0.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_drop_cleanup.main-{closure#0}.generator_drop.0.panic-abort.mir')
-rw-r--r--tests/mir-opt/generator_drop_cleanup.main-{closure#0}.generator_drop.0.panic-abort.mir82
1 files changed, 82 insertions, 0 deletions
diff --git a/tests/mir-opt/generator_drop_cleanup.main-{closure#0}.generator_drop.0.panic-abort.mir b/tests/mir-opt/generator_drop_cleanup.main-{closure#0}.generator_drop.0.panic-abort.mir
new file mode 100644
index 000000000..958078b97
--- /dev/null
+++ b/tests/mir-opt/generator_drop_cleanup.main-{closure#0}.generator_drop.0.panic-abort.mir
@@ -0,0 +1,82 @@
+// MIR for `main::{closure#0}` 0 generator_drop
+/* generator_layout = GeneratorLayout {
+ field_tys: {
+ _0: GeneratorSavedTy {
+ ty: std::string::String,
+ source_info: SourceInfo {
+ span: $DIR/generator_drop_cleanup.rs:11:13: 11:15 (#0),
+ scope: scope[0],
+ },
+ ignore_for_traits: false,
+ },
+ },
+ variant_fields: {
+ Unresumed(0): [],
+ Returned (1): [],
+ Panicked (2): [],
+ Suspend0 (3): [_0],
+ },
+ storage_conflicts: BitMatrix(1x1) {
+ (_0, _0),
+ },
+} */
+
+fn main::{closure#0}(_1: *mut [generator@$DIR/generator_drop_cleanup.rs:10:15: 10:17]) -> () {
+ let mut _0: ();
+ let mut _2: ();
+ let _3: std::string::String;
+ let _4: ();
+ let mut _5: ();
+ let mut _6: ();
+ let mut _7: ();
+ let mut _8: u32;
+ scope 1 {
+ debug _s => (((*_1) as variant#3).0: std::string::String);
+ }
+
+ bb0: {
+ _8 = discriminant((*_1));
+ switchInt(move _8) -> [0: bb5, 3: bb8, otherwise: bb9];
+ }
+
+ bb1: {
+ StorageDead(_5);
+ StorageDead(_4);
+ drop((((*_1) as variant#3).0: std::string::String)) -> [return: bb2, unwind unreachable];
+ }
+
+ bb2: {
+ nop;
+ goto -> bb6;
+ }
+
+ bb3: {
+ return;
+ }
+
+ bb4: {
+ return;
+ }
+
+ bb5: {
+ goto -> bb7;
+ }
+
+ bb6: {
+ goto -> bb3;
+ }
+
+ bb7: {
+ goto -> bb4;
+ }
+
+ bb8: {
+ StorageLive(_4);
+ StorageLive(_5);
+ goto -> bb1;
+ }
+
+ bb9: {
+ return;
+ }
+}