2023-02-24 16:33:22 -05:00
|
|
|
- // MIR for `unwrap_unchecked` before Inline
|
|
|
|
+ // MIR for `unwrap_unchecked` after Inline
|
|
|
|
|
|
|
|
fn unwrap_unchecked(_1: Option<T>) -> T {
|
2023-06-06 09:47:00 -04: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;
|
2023-03-11 15:27:44 +00:00
|
|
|
+ let mut _3: isize;
|
2023-02-24 16:33:22 -05:00
|
|
|
+ scope 2 {
|
2023-06-06 09:47:00 -04:00
|
|
|
+ debug val => _0;
|
2023-02-24 16:33:22 -05:00
|
|
|
+ }
|
|
|
|
+ scope 3 {
|
2023-06-06 09:47:00 -04:00
|
|
|
+ scope 5 (inlined unreachable_unchecked) {
|
2023-02-24 16:33:22 -05:00
|
|
|
+ scope 6 {
|
2023-06-06 09:47:00 -04:00
|
|
|
+ scope 7 (inlined unreachable_unchecked::runtime) {
|
2023-02-24 16:33:22 -05:00
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
2023-06-06 09:47:00 -04:00
|
|
|
+ scope 4 (inlined Option::<T>::is_some) {
|
2023-03-11 15:27:44 +00:00
|
|
|
+ debug self => &_2;
|
2023-02-24 16:33:22 -05:00
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
|
|
|
|
bb0: {
|
2023-06-06 09:47:00 -04:00
|
|
|
StorageLive(_2);
|
|
|
|
_2 = move _1;
|
|
|
|
- _0 = Option::<T>::unwrap_unchecked(move _2) -> [return: bb1, unwind: bb2];
|
2023-03-11 15:27:44 +00:00
|
|
|
+ _3 = discriminant(_2);
|
|
|
|
+ switchInt(move _3) -> [1: bb2, otherwise: bb1];
|
2023-02-24 16:33:22 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
bb1: {
|
2023-06-06 09:47:00 -04:00
|
|
|
- StorageDead(_2);
|
|
|
|
- return;
|
|
|
|
+ unreachable;
|
2023-02-24 16:33:22 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
- bb2 (cleanup): {
|
2023-06-06 09:47:00 -04:00
|
|
|
- resume;
|
2023-02-24 16:33:22 -05:00
|
|
|
+ bb2: {
|
2023-06-06 09:47:00 -04:00
|
|
|
+ _0 = move ((_2 as Some).0: T);
|
|
|
|
+ StorageDead(_2);
|
|
|
|
+ return;
|
2023-02-24 16:33:22 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|