// MIR for `range_iter_next` after PreCodegen fn range_iter_next(_1: &mut std::ops::Range) -> Option { debug it => _1; let mut _0: std::option::Option; scope 1 (inlined iter::range::>::next) { scope 2 (inlined as iter::range::RangeIteratorImpl>::spec_next) { let mut _4: bool; let _5: u32; let mut _6: u32; scope 3 { } scope 4 (inlined std::cmp::impls::::lt) { let mut _2: u32; let mut _3: u32; } } } bb0: { StorageLive(_5); StorageLive(_4); StorageLive(_2); _2 = copy ((*_1).0: u32); StorageLive(_3); _3 = copy ((*_1).1: u32); _4 = Lt(move _2, move _3); StorageDead(_3); StorageDead(_2); switchInt(move _4) -> [0: bb1, otherwise: bb2]; } bb1: { _0 = const Option::::None; goto -> bb4; } bb2: { _5 = copy ((*_1).0: u32); StorageLive(_6); _6 = ::forward_unchecked(copy _5, const 1_usize) -> [return: bb3, unwind unreachable]; } bb3: { ((*_1).0: u32) = move _6; StorageDead(_6); _0 = Option::::Some(copy _5); goto -> bb4; } bb4: { StorageDead(_4); StorageDead(_5); return; } } ALLOC0 (size: 8, align: 4) { 00 00 00 00 __ __ __ __ │ ....░░░░ }