// MIR for `reverse_loop` after PreCodegen fn reverse_loop(_1: &[T], _2: impl Fn(&T)) -> () { debug slice => _1; debug f => _2; let mut _0: (); let mut _13: std::slice::Iter<'_, T>; let mut _14: std::iter::Rev>; let mut _15: std::iter::Rev>; let mut _17: std::option::Option<&T>; let mut _18: isize; let mut _20: &impl Fn(&T); let mut _21: (&T,); let _22: (); scope 1 { debug iter => _15; let _19: &T; scope 2 { debug x => _19; } scope 25 (inlined > as Iterator>::next) { debug self => &_15; let mut _16: &mut std::slice::Iter<'_, T>; } } scope 3 (inlined core::slice::::iter) { debug self => _1; scope 4 (inlined std::slice::Iter::<'_, T>::new) { debug slice => _1; let _4: *const T; let mut _5: bool; let mut _6: usize; let mut _8: usize; let mut _9: *mut T; let mut _11: std::ptr::NonNull; let mut _12: *const T; scope 5 { debug ptr => _4; scope 6 { let _7: *const T; scope 7 { debug end_or_len => _7; scope 13 (inlined NonNull::::new_unchecked) { debug ptr => _9; let mut _10: *const T; scope 14 { scope 15 (inlined NonNull::::new_unchecked::runtime::) { debug ptr => _9; scope 16 (inlined ptr::mut_ptr::::is_null) { debug self => _9; let mut _23: *mut u8; scope 17 { scope 18 (inlined ptr::mut_ptr::::is_null::runtime_impl) { debug ptr => _23; scope 19 (inlined ptr::mut_ptr::::addr) { debug self => _23; scope 20 { scope 21 (inlined ptr::mut_ptr::::cast::<()>) { debug self => _23; } } } } } } } } } } scope 9 (inlined invalid::) { debug addr => _8; scope 10 { } } scope 11 (inlined ptr::const_ptr::::add) { debug self => _4; debug count => _6; scope 12 { } } } } scope 8 (inlined core::slice::::as_ptr) { debug self => _1; let mut _3: *const [T]; } } } scope 22 (inlined as Iterator>::rev) { debug self => _13; scope 23 (inlined Rev::>::new) { debug iter => _13; } } scope 24 (inlined > as IntoIterator>::into_iter) { debug self => _14; } bb0: { StorageLive(_13); StorageLive(_4); StorageLive(_3); _3 = &raw const (*_1); _4 = move _3 as *const T (PtrToPtr); StorageDead(_3); StorageLive(_7); StorageLive(_5); _5 = const _; switchInt(move _5) -> [0: bb1, otherwise: bb2]; } bb1: { StorageLive(_6); _6 = Len((*_1)); _7 = Offset(_4, _6); StorageDead(_6); goto -> bb3; } bb2: { StorageLive(_8); _8 = Len((*_1)); _7 = _8 as *const T (Transmute); StorageDead(_8); goto -> bb3; } bb3: { StorageDead(_5); StorageLive(_11); StorageLive(_9); _9 = _4 as *mut T (PtrToPtr); StorageLive(_10); StorageLive(_23); _10 = _9 as *const T (PointerCoercion(MutToConstPointer)); _11 = NonNull:: { pointer: _10 }; StorageDead(_23); StorageDead(_10); StorageDead(_9); StorageLive(_12); _12 = _7; _13 = std::slice::Iter::<'_, T> { ptr: move _11, end_or_len: move _12, _marker: const ZeroSized: PhantomData<&T> }; StorageDead(_12); StorageDead(_11); StorageDead(_7); StorageDead(_4); _14 = Rev::> { iter: move _13 }; StorageDead(_13); StorageLive(_15); _15 = move _14; goto -> bb4; } bb4: { StorageLive(_17); StorageLive(_16); _16 = &mut (_15.0: std::slice::Iter<'_, T>); _17 = as DoubleEndedIterator>::next_back(move _16) -> [return: bb5, unwind: bb11]; } bb5: { StorageDead(_16); _18 = discriminant(_17); switchInt(move _18) -> [0: bb6, 1: bb8, otherwise: bb10]; } bb6: { StorageDead(_17); StorageDead(_15); drop(_2) -> [return: bb7, unwind continue]; } bb7: { return; } bb8: { _19 = ((_17 as Some).0: &T); StorageLive(_20); _20 = &_2; StorageLive(_21); _21 = (_19,); _22 = >::call(move _20, move _21) -> [return: bb9, unwind: bb11]; } bb9: { StorageDead(_21); StorageDead(_20); StorageDead(_17); goto -> bb4; } bb10: { unreachable; } bb11 (cleanup): { drop(_2) -> [return: bb12, unwind terminate]; } bb12 (cleanup): { resume; } }