// MIR for `forward_loop` after PreCodegen fn forward_loop(_1: &[T], _2: impl Fn(&T)) -> () { debug slice => _1; debug f => _2; let mut _0: (); let mut _11: std::slice::Iter<'_, T>; let mut _12: std::slice::Iter<'_, T>; let mut _13: &mut std::slice::Iter<'_, T>; let mut _14: std::option::Option<&T>; let mut _15: isize; let mut _17: &impl Fn(&T); let mut _18: (&T,); let _19: (); scope 1 { debug iter => _12; let _16: &T; scope 2 { debug x => _16; } } scope 3 (inlined core::slice::::iter) { scope 4 (inlined std::slice::Iter::<'_, T>::new) { let _3: usize; let mut _7: *mut T; let mut _8: *mut T; let mut _10: *const T; scope 5 { let _6: std::ptr::NonNull; scope 6 { let _9: *const T; scope 7 { } scope 12 (inlined without_provenance::) { } scope 13 (inlined NonNull::::as_ptr) { } scope 14 (inlined std::ptr::mut_ptr::::add) { } } scope 8 (inlined as From<&[T]>>::from) { scope 9 (inlined NonNull::<[T]>::from_ref) { let mut _4: *const [T]; } } scope 10 (inlined NonNull::<[T]>::cast::) { let mut _5: *const T; scope 11 (inlined NonNull::<[T]>::as_ptr) { } } } } } scope 15 (inlined as IntoIterator>::into_iter) { } bb0: { StorageLive(_3); StorageLive(_6); StorageLive(_4); StorageLive(_5); _3 = PtrMetadata(copy _1); _4 = &raw const (*_1); _5 = copy _4 as *const T (PtrToPtr); _6 = NonNull:: { pointer: copy _5 }; StorageLive(_9); switchInt(const ::IS_ZST) -> [0: bb1, otherwise: bb2]; } bb1: { StorageLive(_8); StorageLive(_7); _7 = copy _4 as *mut T (PtrToPtr); _8 = Offset(copy _7, copy _3); StorageDead(_7); _9 = move _8 as *const T (PtrToPtr); StorageDead(_8); goto -> bb3; } bb2: { _9 = copy _3 as *const T (Transmute); goto -> bb3; } bb3: { StorageLive(_10); _10 = copy _9; _11 = std::slice::Iter::<'_, T> { ptr: copy _6, end_or_len: move _10, _marker: const ZeroSized: PhantomData<&T> }; StorageDead(_10); StorageDead(_9); StorageDead(_5); StorageDead(_4); StorageDead(_6); StorageDead(_3); StorageLive(_12); _12 = copy _11; goto -> bb4; } bb4: { StorageLive(_14); _13 = &mut _12; _14 = as Iterator>::next(move _13) -> [return: bb5, unwind unreachable]; } bb5: { _15 = discriminant(_14); switchInt(move _15) -> [0: bb6, 1: bb8, otherwise: bb10]; } bb6: { StorageDead(_14); StorageDead(_12); drop(_2) -> [return: bb7, unwind unreachable]; } bb7: { return; } bb8: { _16 = copy ((_14 as Some).0: &T); StorageLive(_17); _17 = &_2; StorageLive(_18); _18 = (copy _16,); _19 = >::call(move _17, move _18) -> [return: bb9, unwind unreachable]; } bb9: { StorageDead(_18); StorageDead(_17); StorageDead(_14); goto -> bb4; } bb10: { unreachable; } }