// MIR for `shift_signed` after built fn shift_signed(_1: i8, _2: u128, _3: i8, _4: i32, _5: i128) -> ([i8; 3], [u128; 3]) { debug small => _1; // in scope 0 at $DIR/shifts.rs:+0:17: +0:22 debug big => _2; // in scope 0 at $DIR/shifts.rs:+0:28: +0:31 debug a => _3; // in scope 0 at $DIR/shifts.rs:+0:39: +0:40 debug b => _4; // in scope 0 at $DIR/shifts.rs:+0:46: +0:47 debug c => _5; // in scope 0 at $DIR/shifts.rs:+0:54: +0:55 let mut _0: ([i8; 3], [u128; 3]); // return place in scope 0 at $DIR/shifts.rs:+0:66: +0:86 let mut _6: [i8; 3]; // in scope 0 at $DIR/shifts.rs:+2:9: +2:45 let mut _7: i8; // in scope 0 at $DIR/shifts.rs:+2:10: +2:20 let mut _8: i8; // in scope 0 at $DIR/shifts.rs:+2:10: +2:15 let mut _9: i8; // in scope 0 at $DIR/shifts.rs:+2:19: +2:20 let mut _10: u8; // in scope 0 at $DIR/shifts.rs:+2:10: +2:20 let mut _11: bool; // in scope 0 at $DIR/shifts.rs:+2:10: +2:20 let mut _12: i8; // in scope 0 at $DIR/shifts.rs:+2:22: +2:32 let mut _13: i8; // in scope 0 at $DIR/shifts.rs:+2:22: +2:27 let mut _14: i32; // in scope 0 at $DIR/shifts.rs:+2:31: +2:32 let mut _15: u32; // in scope 0 at $DIR/shifts.rs:+2:22: +2:32 let mut _16: bool; // in scope 0 at $DIR/shifts.rs:+2:22: +2:32 let mut _17: i8; // in scope 0 at $DIR/shifts.rs:+2:34: +2:44 let mut _18: i8; // in scope 0 at $DIR/shifts.rs:+2:34: +2:39 let mut _19: i128; // in scope 0 at $DIR/shifts.rs:+2:43: +2:44 let mut _20: u128; // in scope 0 at $DIR/shifts.rs:+2:34: +2:44 let mut _21: bool; // in scope 0 at $DIR/shifts.rs:+2:34: +2:44 let mut _22: [u128; 3]; // in scope 0 at $DIR/shifts.rs:+3:9: +3:39 let mut _23: u128; // in scope 0 at $DIR/shifts.rs:+3:10: +3:18 let mut _24: u128; // in scope 0 at $DIR/shifts.rs:+3:10: +3:13 let mut _25: i8; // in scope 0 at $DIR/shifts.rs:+3:17: +3:18 let mut _26: u8; // in scope 0 at $DIR/shifts.rs:+3:10: +3:18 let mut _27: bool; // in scope 0 at $DIR/shifts.rs:+3:10: +3:18 let mut _28: u128; // in scope 0 at $DIR/shifts.rs:+3:20: +3:28 let mut _29: u128; // in scope 0 at $DIR/shifts.rs:+3:20: +3:23 let mut _30: i32; // in scope 0 at $DIR/shifts.rs:+3:27: +3:28 let mut _31: u32; // in scope 0 at $DIR/shifts.rs:+3:20: +3:28 let mut _32: bool; // in scope 0 at $DIR/shifts.rs:+3:20: +3:28 let mut _33: u128; // in scope 0 at $DIR/shifts.rs:+3:30: +3:38 let mut _34: u128; // in scope 0 at $DIR/shifts.rs:+3:30: +3:33 let mut _35: i128; // in scope 0 at $DIR/shifts.rs:+3:37: +3:38 let mut _36: u128; // in scope 0 at $DIR/shifts.rs:+3:30: +3:38 let mut _37: bool; // in scope 0 at $DIR/shifts.rs:+3:30: +3:38 bb0: { StorageLive(_6); // scope 0 at $DIR/shifts.rs:+2:9: +2:45 StorageLive(_7); // scope 0 at $DIR/shifts.rs:+2:10: +2:20 StorageLive(_8); // scope 0 at $DIR/shifts.rs:+2:10: +2:15 _8 = _1; // scope 0 at $DIR/shifts.rs:+2:10: +2:15 StorageLive(_9); // scope 0 at $DIR/shifts.rs:+2:19: +2:20 _9 = _3; // scope 0 at $DIR/shifts.rs:+2:19: +2:20 _10 = _9 as u8 (IntToInt); // scope 0 at $DIR/shifts.rs:+2:10: +2:20 _11 = Lt(move _10, const 8_u8); // scope 0 at $DIR/shifts.rs:+2:10: +2:20 assert(move _11, "attempt to shift right by `{}`, which would overflow", _9) -> [success: bb1, unwind: bb7]; // scope 0 at $DIR/shifts.rs:+2:10: +2:20 } bb1: { _7 = Shr(move _8, move _9); // scope 0 at $DIR/shifts.rs:+2:10: +2:20 StorageDead(_9); // scope 0 at $DIR/shifts.rs:+2:19: +2:20 StorageDead(_8); // scope 0 at $DIR/shifts.rs:+2:19: +2:20 StorageLive(_12); // scope 0 at $DIR/shifts.rs:+2:22: +2:32 StorageLive(_13); // scope 0 at $DIR/shifts.rs:+2:22: +2:27 _13 = _1; // scope 0 at $DIR/shifts.rs:+2:22: +2:27 StorageLive(_14); // scope 0 at $DIR/shifts.rs:+2:31: +2:32 _14 = _4; // scope 0 at $DIR/shifts.rs:+2:31: +2:32 _15 = _14 as u32 (IntToInt); // scope 0 at $DIR/shifts.rs:+2:22: +2:32 _16 = Lt(move _15, const 8_u32); // scope 0 at $DIR/shifts.rs:+2:22: +2:32 assert(move _16, "attempt to shift right by `{}`, which would overflow", _14) -> [success: bb2, unwind: bb7]; // scope 0 at $DIR/shifts.rs:+2:22: +2:32 } bb2: { _12 = Shr(move _13, move _14); // scope 0 at $DIR/shifts.rs:+2:22: +2:32 StorageDead(_14); // scope 0 at $DIR/shifts.rs:+2:31: +2:32 StorageDead(_13); // scope 0 at $DIR/shifts.rs:+2:31: +2:32 StorageLive(_17); // scope 0 at $DIR/shifts.rs:+2:34: +2:44 StorageLive(_18); // scope 0 at $DIR/shifts.rs:+2:34: +2:39 _18 = _1; // scope 0 at $DIR/shifts.rs:+2:34: +2:39 StorageLive(_19); // scope 0 at $DIR/shifts.rs:+2:43: +2:44 _19 = _5; // scope 0 at $DIR/shifts.rs:+2:43: +2:44 _20 = _19 as u128 (IntToInt); // scope 0 at $DIR/shifts.rs:+2:34: +2:44 _21 = Lt(move _20, const 8_u128); // scope 0 at $DIR/shifts.rs:+2:34: +2:44 assert(move _21, "attempt to shift right by `{}`, which would overflow", _19) -> [success: bb3, unwind: bb7]; // scope 0 at $DIR/shifts.rs:+2:34: +2:44 } bb3: { _17 = Shr(move _18, move _19); // scope 0 at $DIR/shifts.rs:+2:34: +2:44 StorageDead(_19); // scope 0 at $DIR/shifts.rs:+2:43: +2:44 StorageDead(_18); // scope 0 at $DIR/shifts.rs:+2:43: +2:44 _6 = [move _7, move _12, move _17]; // scope 0 at $DIR/shifts.rs:+2:9: +2:45 StorageDead(_17); // scope 0 at $DIR/shifts.rs:+2:44: +2:45 StorageDead(_12); // scope 0 at $DIR/shifts.rs:+2:44: +2:45 StorageDead(_7); // scope 0 at $DIR/shifts.rs:+2:44: +2:45 StorageLive(_22); // scope 0 at $DIR/shifts.rs:+3:9: +3:39 StorageLive(_23); // scope 0 at $DIR/shifts.rs:+3:10: +3:18 StorageLive(_24); // scope 0 at $DIR/shifts.rs:+3:10: +3:13 _24 = _2; // scope 0 at $DIR/shifts.rs:+3:10: +3:13 StorageLive(_25); // scope 0 at $DIR/shifts.rs:+3:17: +3:18 _25 = _3; // scope 0 at $DIR/shifts.rs:+3:17: +3:18 _26 = _25 as u8 (IntToInt); // scope 0 at $DIR/shifts.rs:+3:10: +3:18 _27 = Lt(move _26, const 128_u8); // scope 0 at $DIR/shifts.rs:+3:10: +3:18 assert(move _27, "attempt to shift left by `{}`, which would overflow", _25) -> [success: bb4, unwind: bb7]; // scope 0 at $DIR/shifts.rs:+3:10: +3:18 } bb4: { _23 = Shl(move _24, move _25); // scope 0 at $DIR/shifts.rs:+3:10: +3:18 StorageDead(_25); // scope 0 at $DIR/shifts.rs:+3:17: +3:18 StorageDead(_24); // scope 0 at $DIR/shifts.rs:+3:17: +3:18 StorageLive(_28); // scope 0 at $DIR/shifts.rs:+3:20: +3:28 StorageLive(_29); // scope 0 at $DIR/shifts.rs:+3:20: +3:23 _29 = _2; // scope 0 at $DIR/shifts.rs:+3:20: +3:23 StorageLive(_30); // scope 0 at $DIR/shifts.rs:+3:27: +3:28 _30 = _4; // scope 0 at $DIR/shifts.rs:+3:27: +3:28 _31 = _30 as u32 (IntToInt); // scope 0 at $DIR/shifts.rs:+3:20: +3:28 _32 = Lt(move _31, const 128_u32); // scope 0 at $DIR/shifts.rs:+3:20: +3:28 assert(move _32, "attempt to shift left by `{}`, which would overflow", _30) -> [success: bb5, unwind: bb7]; // scope 0 at $DIR/shifts.rs:+3:20: +3:28 } bb5: { _28 = Shl(move _29, move _30); // scope 0 at $DIR/shifts.rs:+3:20: +3:28 StorageDead(_30); // scope 0 at $DIR/shifts.rs:+3:27: +3:28 StorageDead(_29); // scope 0 at $DIR/shifts.rs:+3:27: +3:28 StorageLive(_33); // scope 0 at $DIR/shifts.rs:+3:30: +3:38 StorageLive(_34); // scope 0 at $DIR/shifts.rs:+3:30: +3:33 _34 = _2; // scope 0 at $DIR/shifts.rs:+3:30: +3:33 StorageLive(_35); // scope 0 at $DIR/shifts.rs:+3:37: +3:38 _35 = _5; // scope 0 at $DIR/shifts.rs:+3:37: +3:38 _36 = _35 as u128 (IntToInt); // scope 0 at $DIR/shifts.rs:+3:30: +3:38 _37 = Lt(move _36, const 128_u128); // scope 0 at $DIR/shifts.rs:+3:30: +3:38 assert(move _37, "attempt to shift left by `{}`, which would overflow", _35) -> [success: bb6, unwind: bb7]; // scope 0 at $DIR/shifts.rs:+3:30: +3:38 } bb6: { _33 = Shl(move _34, move _35); // scope 0 at $DIR/shifts.rs:+3:30: +3:38 StorageDead(_35); // scope 0 at $DIR/shifts.rs:+3:37: +3:38 StorageDead(_34); // scope 0 at $DIR/shifts.rs:+3:37: +3:38 _22 = [move _23, move _28, move _33]; // scope 0 at $DIR/shifts.rs:+3:9: +3:39 StorageDead(_33); // scope 0 at $DIR/shifts.rs:+3:38: +3:39 StorageDead(_28); // scope 0 at $DIR/shifts.rs:+3:38: +3:39 StorageDead(_23); // scope 0 at $DIR/shifts.rs:+3:38: +3:39 _0 = (move _6, move _22); // scope 0 at $DIR/shifts.rs:+1:5: +4:6 StorageDead(_22); // scope 0 at $DIR/shifts.rs:+4:5: +4:6 StorageDead(_6); // scope 0 at $DIR/shifts.rs:+4:5: +4:6 return; // scope 0 at $DIR/shifts.rs:+5:2: +5:2 } bb7 (cleanup): { resume; // scope 0 at $DIR/shifts.rs:+0:1: +5:2 } }