summaryrefslogtreecommitdiffstats
path: root/tests/mir-opt/gvn.wrap_unwrap.GVN.panic-unwind.diff
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-30 18:31:44 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-30 18:31:44 +0000
commitc23a457e72abe608715ac76f076f47dc42af07a5 (patch)
tree2772049aaf84b5c9d0ed12ec8d86812f7a7904b6 /tests/mir-opt/gvn.wrap_unwrap.GVN.panic-unwind.diff
parentReleasing progress-linux version 1.73.0+dfsg1-1~progress7.99u1. (diff)
downloadrustc-c23a457e72abe608715ac76f076f47dc42af07a5.tar.xz
rustc-c23a457e72abe608715ac76f076f47dc42af07a5.zip
Merging upstream version 1.74.1+dfsg1.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'tests/mir-opt/gvn.wrap_unwrap.GVN.panic-unwind.diff')
-rw-r--r--tests/mir-opt/gvn.wrap_unwrap.GVN.panic-unwind.diff45
1 files changed, 45 insertions, 0 deletions
diff --git a/tests/mir-opt/gvn.wrap_unwrap.GVN.panic-unwind.diff b/tests/mir-opt/gvn.wrap_unwrap.GVN.panic-unwind.diff
new file mode 100644
index 000000000..edc05f99f
--- /dev/null
+++ b/tests/mir-opt/gvn.wrap_unwrap.GVN.panic-unwind.diff
@@ -0,0 +1,45 @@
+- // MIR for `wrap_unwrap` before GVN
++ // MIR for `wrap_unwrap` after GVN
+
+ fn wrap_unwrap(_1: T) -> T {
+ debug x => _1;
+ let mut _0: T;
+ let mut _2: std::option::Option<T>;
+ let mut _3: T;
+ let mut _4: isize;
+ let _5: T;
+ let mut _6: !;
+ scope 1 {
+ debug y => _5;
+ }
+
+ bb0: {
+ StorageLive(_2);
+- StorageLive(_3);
+- _3 = _1;
+- _2 = Option::<T>::Some(move _3);
+- StorageDead(_3);
++ _2 = Option::<T>::Some(_1);
+ _4 = discriminant(_2);
+ switchInt(move _4) -> [0: bb1, 1: bb3, otherwise: bb2];
+ }
+
+ bb1: {
+ StorageLive(_6);
+ _6 = begin_panic::<&str>(const "explicit panic") -> unwind continue;
+ }
+
+ bb2: {
+ unreachable;
+ }
+
+ bb3: {
+- StorageLive(_5);
+ _5 = ((_2 as Some).0: T);
+ _0 = _5;
+- StorageDead(_5);
+ StorageDead(_2);
+ return;
+ }
+ }
+