// MIR for `enumerated_loop` after PreCodegen fn enumerated_loop(_1: &[T], _2: impl Fn(usize, &T)) -> () { debug slice => _1; debug f => _2; let mut _0: (); let mut _13: std::slice::Iter<'_, T>; let mut _14: std::iter::Enumerate>; let mut _15: std::iter::Enumerate>; let mut _16: &mut std::iter::Enumerate>; let mut _17: std::option::Option<(usize, &T)>; let mut _18: isize; let mut _21: &impl Fn(usize, &T); let mut _22: (usize, &T); let _23: (); scope 1 { debug iter => _15; let _19: usize; let _20: &T; scope 2 { debug i => _19; debug x => _20; } } scope 3 (inlined core::slice::::iter) { debug self => _1; scope 4 (inlined std::slice::Iter::<'_, T>::new) { debug slice => _1; let _3: usize; let mut _5: std::ptr::NonNull<[T]>; let mut _8: bool; let mut _9: *mut T; let mut _10: *mut T; let mut _12: *const T; scope 5 { debug len => _3; let _7: std::ptr::NonNull; scope 6 { debug ptr => _7; scope 7 { let _11: *const T; scope 8 { debug end_or_len => _11; } scope 14 (inlined without_provenance::) { debug addr => _3; scope 15 { } } scope 16 (inlined NonNull::::as_ptr) { debug self => _7; } scope 17 (inlined std::ptr::mut_ptr::::add) { debug self => _9; debug count => _3; scope 18 { } } } } scope 9 (inlined as From<&[T]>>::from) { debug reference => _1; let mut _4: *const [T]; scope 10 { } } scope 11 (inlined NonNull::<[T]>::cast::) { debug self => _5; let mut _6: *const T; scope 12 { scope 13 (inlined NonNull::<[T]>::as_ptr) { debug self => _5; } } } } } } scope 19 (inlined as Iterator>::enumerate) { debug self => _13; scope 20 (inlined Enumerate::>::new) { debug iter => _13; } } scope 21 (inlined > as IntoIterator>::into_iter) { debug self => _14; } bb0: { StorageLive(_13); StorageLive(_3); StorageLive(_7); StorageLive(_4); StorageLive(_6); _3 = Len((*_1)); StorageLive(_5); _4 = &raw const (*_1); _5 = NonNull::<[T]> { pointer: _4 }; _6 = _4 as *const T (PtrToPtr); _7 = NonNull:: { pointer: _6 }; StorageDead(_5); StorageLive(_11); StorageLive(_8); _8 = const _; switchInt(move _8) -> [0: bb1, otherwise: bb2]; } bb1: { StorageLive(_10); StorageLive(_9); _9 = _4 as *mut T (PtrToPtr); _10 = Offset(_9, _3); StorageDead(_9); _11 = move _10 as *const T (PointerCoercion(MutToConstPointer)); StorageDead(_10); goto -> bb3; } bb2: { _11 = _3 as *const T (Transmute); goto -> bb3; } bb3: { StorageDead(_8); StorageLive(_12); _12 = _11; _13 = std::slice::Iter::<'_, T> { ptr: _7, end_or_len: move _12, _marker: const ZeroSized: PhantomData<&T> }; StorageDead(_12); StorageDead(_11); StorageDead(_6); StorageDead(_4); StorageDead(_7); StorageDead(_3); _14 = Enumerate::> { iter: _13, count: const 0_usize }; StorageDead(_13); StorageLive(_15); _15 = _14; goto -> bb4; } bb4: { StorageLive(_17); StorageLive(_16); _16 = &mut _15; _17 = > as Iterator>::next(move _16) -> [return: bb5, unwind unreachable]; } 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 unreachable]; } bb7: { return; } bb8: { _19 = (((_17 as Some).0: (usize, &T)).0: usize); _20 = (((_17 as Some).0: (usize, &T)).1: &T); StorageLive(_21); _21 = &_2; StorageLive(_22); _22 = (_19, _20); _23 = >::call(move _21, move _22) -> [return: bb9, unwind unreachable]; } bb9: { StorageDead(_22); StorageDead(_21); StorageDead(_17); goto -> bb4; } bb10: { unreachable; } }