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

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

58 lines
1.4 KiB
Diff
Raw Normal View History

2023-02-24 15:33:22 -06:00
- // MIR for `unwrap_unchecked` before Inline
+ // MIR for `unwrap_unchecked` after Inline
fn unwrap_unchecked(_1: Option<T>) -> T {
2023-06-06 08:47:00 -05:00
debug slf => _1;
let mut _0: T;
let mut _2: std::option::Option<T>;
+ scope 1 (inlined #[track_caller] Option::<T>::unwrap_unchecked) {
+ debug self => _2;
2024-02-07 09:30:39 -06:00
+ let mut _3: isize;
2023-02-24 15:33:22 -06:00
+ scope 2 {
2023-06-06 08:47:00 -05:00
+ debug val => _0;
2023-02-24 15:33:22 -06:00
+ }
+ scope 3 {
2024-02-07 09:30:39 -06:00
+ scope 4 (inlined unreachable_unchecked) {
+ let mut _4: bool;
+ let _5: ();
+ scope 5 {
2023-02-24 15:33:22 -06:00
+ }
+ }
+ }
+ }
bb0: {
2023-06-06 08:47:00 -05:00
StorageLive(_2);
_2 = move _1;
- _0 = Option::<T>::unwrap_unchecked(move _2) -> [return: bb1, unwind: bb2];
2023-08-17 12:06:55 -05:00
+ StorageLive(_3);
+ StorageLive(_5);
2024-02-07 09:30:39 -06:00
+ _3 = discriminant(_2);
+ switchInt(move _3) -> [0: bb1, 1: bb3, otherwise: bb2];
}
bb1: {
- StorageDead(_2);
- return;
+ StorageLive(_4);
+ _4 = cfg!(debug_assertions);
+ assume(_4);
+ _5 = unreachable_unchecked::precondition_check() -> [return: bb2, unwind unreachable];
}
- bb2 (cleanup): {
- resume;
+ bb2: {
+ unreachable;
+ }
+
+ bb3: {
2023-06-06 08:47:00 -05:00
+ _0 = move ((_2 as Some).0: T);
+ StorageDead(_5);
2023-08-17 12:06:55 -05:00
+ StorageDead(_3);
2024-02-07 09:30:39 -06:00
+ StorageDead(_2);
+ return;
2023-02-24 15:33:22 -06:00
}
}