summaryrefslogtreecommitdiffstats
path: root/tests/mir-opt/issues
diff options
context:
space:
mode:
Diffstat (limited to 'tests/mir-opt/issues')
-rw-r--r--tests/mir-opt/issues/issue_59352.num_to_digit.PreCodegen.after.panic-abort.mir42
-rw-r--r--tests/mir-opt/issues/issue_59352.num_to_digit.PreCodegen.after.panic-unwind.mir42
-rw-r--r--tests/mir-opt/issues/issue_59352.rs1
-rw-r--r--tests/mir-opt/issues/issue_75439.rs1
4 files changed, 50 insertions, 36 deletions
diff --git a/tests/mir-opt/issues/issue_59352.num_to_digit.PreCodegen.after.panic-abort.mir b/tests/mir-opt/issues/issue_59352.num_to_digit.PreCodegen.after.panic-abort.mir
index f8c859418..5d25c6557 100644
--- a/tests/mir-opt/issues/issue_59352.num_to_digit.PreCodegen.after.panic-abort.mir
+++ b/tests/mir-opt/issues/issue_59352.num_to_digit.PreCodegen.after.panic-abort.mir
@@ -3,56 +3,61 @@
fn num_to_digit(_1: char) -> u32 {
debug num => _1;
let mut _0: u32;
- let mut _4: std::option::Option<u32>;
+ let mut _5: std::option::Option<u32>;
scope 1 (inlined char::methods::<impl char>::is_digit) {
debug self => _1;
debug radix => const 8_u32;
let _2: std::option::Option<u32>;
- let mut _7: &std::option::Option<u32>;
+ let mut _3: &std::option::Option<u32>;
scope 2 (inlined Option::<u32>::is_some) {
- debug self => _7;
- let mut _3: isize;
+ debug self => _3;
+ let mut _4: isize;
}
}
scope 3 (inlined #[track_caller] Option::<u32>::unwrap) {
- debug self => _4;
- let mut _5: isize;
- let mut _6: !;
+ debug self => _5;
+ let mut _6: isize;
+ let mut _7: !;
scope 4 {
debug val => _0;
}
}
bb0: {
- StorageLive(_7);
+ StorageLive(_3);
StorageLive(_2);
_2 = char::methods::<impl char>::to_digit(_1, const 8_u32) -> [return: bb1, unwind unreachable];
}
bb1: {
- _3 = discriminant(_2);
- StorageDead(_7);
+ _3 = &_2;
+ StorageLive(_4);
+ _4 = discriminant(_2);
+ StorageDead(_3);
StorageDead(_2);
- switchInt(move _3) -> [1: bb2, otherwise: bb7];
+ switchInt(move _4) -> [1: bb2, otherwise: bb7];
}
bb2: {
- StorageLive(_4);
- _4 = char::methods::<impl char>::to_digit(move _1, const 8_u32) -> [return: bb3, unwind unreachable];
+ StorageDead(_4);
+ StorageLive(_5);
+ _5 = char::methods::<impl char>::to_digit(move _1, const 8_u32) -> [return: bb3, unwind unreachable];
}
bb3: {
- _5 = discriminant(_4);
- switchInt(move _5) -> [0: bb4, 1: bb5, otherwise: bb6];
+ StorageLive(_6);
+ _6 = discriminant(_5);
+ switchInt(move _6) -> [0: bb4, 1: bb5, otherwise: bb6];
}
bb4: {
- _6 = core::panicking::panic(const "called `Option::unwrap()` on a `None` value") -> unwind unreachable;
+ _7 = core::panicking::panic(const "called `Option::unwrap()` on a `None` value") -> unwind unreachable;
}
bb5: {
- _0 = move ((_4 as Some).0: u32);
- StorageDead(_4);
+ _0 = move ((_5 as Some).0: u32);
+ StorageDead(_6);
+ StorageDead(_5);
goto -> bb8;
}
@@ -61,6 +66,7 @@ fn num_to_digit(_1: char) -> u32 {
}
bb7: {
+ StorageDead(_4);
_0 = const 0_u32;
goto -> bb8;
}
diff --git a/tests/mir-opt/issues/issue_59352.num_to_digit.PreCodegen.after.panic-unwind.mir b/tests/mir-opt/issues/issue_59352.num_to_digit.PreCodegen.after.panic-unwind.mir
index df7392edc..4677c0108 100644
--- a/tests/mir-opt/issues/issue_59352.num_to_digit.PreCodegen.after.panic-unwind.mir
+++ b/tests/mir-opt/issues/issue_59352.num_to_digit.PreCodegen.after.panic-unwind.mir
@@ -3,56 +3,61 @@
fn num_to_digit(_1: char) -> u32 {
debug num => _1;
let mut _0: u32;
- let mut _4: std::option::Option<u32>;
+ let mut _5: std::option::Option<u32>;
scope 1 (inlined char::methods::<impl char>::is_digit) {
debug self => _1;
debug radix => const 8_u32;
let _2: std::option::Option<u32>;
- let mut _7: &std::option::Option<u32>;
+ let mut _3: &std::option::Option<u32>;
scope 2 (inlined Option::<u32>::is_some) {
- debug self => _7;
- let mut _3: isize;
+ debug self => _3;
+ let mut _4: isize;
}
}
scope 3 (inlined #[track_caller] Option::<u32>::unwrap) {
- debug self => _4;
- let mut _5: isize;
- let mut _6: !;
+ debug self => _5;
+ let mut _6: isize;
+ let mut _7: !;
scope 4 {
debug val => _0;
}
}
bb0: {
- StorageLive(_7);
+ StorageLive(_3);
StorageLive(_2);
_2 = char::methods::<impl char>::to_digit(_1, const 8_u32) -> [return: bb1, unwind continue];
}
bb1: {
- _3 = discriminant(_2);
- StorageDead(_7);
+ _3 = &_2;
+ StorageLive(_4);
+ _4 = discriminant(_2);
+ StorageDead(_3);
StorageDead(_2);
- switchInt(move _3) -> [1: bb2, otherwise: bb7];
+ switchInt(move _4) -> [1: bb2, otherwise: bb7];
}
bb2: {
- StorageLive(_4);
- _4 = char::methods::<impl char>::to_digit(move _1, const 8_u32) -> [return: bb3, unwind continue];
+ StorageDead(_4);
+ StorageLive(_5);
+ _5 = char::methods::<impl char>::to_digit(move _1, const 8_u32) -> [return: bb3, unwind continue];
}
bb3: {
- _5 = discriminant(_4);
- switchInt(move _5) -> [0: bb4, 1: bb5, otherwise: bb6];
+ StorageLive(_6);
+ _6 = discriminant(_5);
+ switchInt(move _6) -> [0: bb4, 1: bb5, otherwise: bb6];
}
bb4: {
- _6 = core::panicking::panic(const "called `Option::unwrap()` on a `None` value") -> unwind continue;
+ _7 = core::panicking::panic(const "called `Option::unwrap()` on a `None` value") -> unwind continue;
}
bb5: {
- _0 = move ((_4 as Some).0: u32);
- StorageDead(_4);
+ _0 = move ((_5 as Some).0: u32);
+ StorageDead(_6);
+ StorageDead(_5);
goto -> bb8;
}
@@ -61,6 +66,7 @@ fn num_to_digit(_1: char) -> u32 {
}
bb7: {
+ StorageDead(_4);
_0 = const 0_u32;
goto -> bb8;
}
diff --git a/tests/mir-opt/issues/issue_59352.rs b/tests/mir-opt/issues/issue_59352.rs
index 7cadf8f22..1cbeaec28 100644
--- a/tests/mir-opt/issues/issue_59352.rs
+++ b/tests/mir-opt/issues/issue_59352.rs
@@ -1,3 +1,4 @@
+// skip-filecheck
// EMIT_MIR_FOR_EACH_PANIC_STRATEGY
// This test is a mirror of codegen/issue-59352.rs.
// The LLVM inliner doesn't inline `char::method::is_digit()` and so it doesn't recognize this case
diff --git a/tests/mir-opt/issues/issue_75439.rs b/tests/mir-opt/issues/issue_75439.rs
index 4c749a150..0ab496e47 100644
--- a/tests/mir-opt/issues/issue_75439.rs
+++ b/tests/mir-opt/issues/issue_75439.rs
@@ -1,3 +1,4 @@
+// skip-filecheck
// EMIT_MIR issue_75439.foo.MatchBranchSimplification.diff
// ignore-endian-big