// 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 _11: std::slice::Iter<'_, T>; let mut _12: std::iter::Enumerate>; let mut _13: std::iter::Enumerate>; let mut _21: std::option::Option<(usize, &T)>; let mut _24: &impl Fn(usize, &T); let mut _25: (usize, &T); let _26: (); scope 1 { debug iter => _13; let _22: usize; let _23: &T; scope 2 { debug i => _22; debug x => _23; } scope 18 (inlined > as Iterator>::next) { let mut _14: &mut std::slice::Iter<'_, T>; let mut _15: std::option::Option<&T>; let mut _19: (usize, bool); let mut _20: (usize, &T); scope 19 { let _18: usize; scope 24 { } } scope 20 { scope 21 { scope 27 (inlined as FromResidual>>::from_residual) { } } } scope 22 { scope 23 { } } scope 25 (inlined as Try>::branch) { let mut _16: isize; let _17: &T; scope 26 { } } } } 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 Iterator>::enumerate) { scope 16 (inlined Enumerate::>::new) { } } scope 17 (inlined > as IntoIterator>::into_iter) { } bb0: { StorageLive(_11); 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); _12 = Enumerate::> { iter: copy _11, count: const 0_usize }; StorageDead(_11); StorageLive(_13); _13 = copy _12; goto -> bb4; } bb4: { StorageLive(_21); StorageLive(_18); StorageLive(_19); StorageLive(_15); StorageLive(_14); _14 = &mut (_13.0: std::slice::Iter<'_, T>); _15 = as Iterator>::next(move _14) -> [return: bb5, unwind unreachable]; } bb5: { StorageDead(_14); StorageLive(_16); _16 = discriminant(_15); switchInt(move _16) -> [0: bb6, 1: bb8, otherwise: bb11]; } bb6: { StorageDead(_16); StorageDead(_15); StorageDead(_19); StorageDead(_18); StorageDead(_21); StorageDead(_13); drop(_2) -> [return: bb7, unwind unreachable]; } bb7: { return; } bb8: { _17 = move ((_15 as Some).0: &T); StorageDead(_16); StorageDead(_15); _18 = copy (_13.1: usize); _19 = AddWithOverflow(copy (_13.1: usize), const 1_usize); assert(!move (_19.1: bool), "attempt to compute `{} + {}`, which would overflow", copy (_13.1: usize), const 1_usize) -> [success: bb9, unwind unreachable]; } bb9: { (_13.1: usize) = move (_19.0: usize); StorageLive(_20); _20 = (copy _18, copy _17); _21 = Option::<(usize, &T)>::Some(move _20); StorageDead(_20); StorageDead(_19); StorageDead(_18); _22 = copy (((_21 as Some).0: (usize, &T)).0: usize); _23 = copy (((_21 as Some).0: (usize, &T)).1: &T); StorageLive(_24); _24 = &_2; StorageLive(_25); _25 = (copy _22, copy _23); _26 = >::call(move _24, move _25) -> [return: bb10, unwind unreachable]; } bb10: { StorageDead(_25); StorageDead(_24); StorageDead(_21); goto -> bb4; } bb11: { unreachable; } }