2023-03-22 03:11:25 -05:00
|
|
|
// MIR for `shift_unsigned` after built
|
|
|
|
|
|
|
|
fn shift_unsigned(_1: u8, _2: i128, _3: u8, _4: u32, _5: u128) -> ([u8; 3], [i128; 3]) {
|
|
|
|
debug small => _1; // in scope 0 at $DIR/shifts.rs:+0:19: +0:24
|
|
|
|
debug big => _2; // in scope 0 at $DIR/shifts.rs:+0:30: +0:33
|
|
|
|
debug a => _3; // in scope 0 at $DIR/shifts.rs:+0:41: +0:42
|
|
|
|
debug b => _4; // in scope 0 at $DIR/shifts.rs:+0:48: +0:49
|
|
|
|
debug c => _5; // in scope 0 at $DIR/shifts.rs:+0:56: +0:57
|
|
|
|
let mut _0: ([u8; 3], [i128; 3]); // return place in scope 0 at $DIR/shifts.rs:+0:68: +0:88
|
|
|
|
let mut _6: [u8; 3]; // in scope 0 at $DIR/shifts.rs:+2:9: +2:45
|
|
|
|
let mut _7: u8; // in scope 0 at $DIR/shifts.rs:+2:10: +2:20
|
|
|
|
let mut _8: u8; // in scope 0 at $DIR/shifts.rs:+2:10: +2:15
|
|
|
|
let mut _9: u8; // in scope 0 at $DIR/shifts.rs:+2:19: +2:20
|
2023-03-22 03:06:19 -05:00
|
|
|
let mut _10: bool; // in scope 0 at $DIR/shifts.rs:+2:10: +2:20
|
|
|
|
let mut _11: u8; // in scope 0 at $DIR/shifts.rs:+2:22: +2:32
|
|
|
|
let mut _12: u8; // in scope 0 at $DIR/shifts.rs:+2:22: +2:27
|
|
|
|
let mut _13: u32; // in scope 0 at $DIR/shifts.rs:+2:31: +2:32
|
|
|
|
let mut _14: bool; // in scope 0 at $DIR/shifts.rs:+2:22: +2:32
|
|
|
|
let mut _15: u8; // in scope 0 at $DIR/shifts.rs:+2:34: +2:44
|
|
|
|
let mut _16: u8; // in scope 0 at $DIR/shifts.rs:+2:34: +2:39
|
|
|
|
let mut _17: u128; // in scope 0 at $DIR/shifts.rs:+2:43: +2:44
|
|
|
|
let mut _18: bool; // in scope 0 at $DIR/shifts.rs:+2:34: +2:44
|
|
|
|
let mut _19: [i128; 3]; // in scope 0 at $DIR/shifts.rs:+3:9: +3:39
|
|
|
|
let mut _20: i128; // in scope 0 at $DIR/shifts.rs:+3:10: +3:18
|
|
|
|
let mut _21: i128; // in scope 0 at $DIR/shifts.rs:+3:10: +3:13
|
|
|
|
let mut _22: u8; // in scope 0 at $DIR/shifts.rs:+3:17: +3:18
|
|
|
|
let mut _23: bool; // in scope 0 at $DIR/shifts.rs:+3:10: +3:18
|
|
|
|
let mut _24: i128; // in scope 0 at $DIR/shifts.rs:+3:20: +3:28
|
|
|
|
let mut _25: i128; // in scope 0 at $DIR/shifts.rs:+3:20: +3:23
|
|
|
|
let mut _26: u32; // in scope 0 at $DIR/shifts.rs:+3:27: +3:28
|
|
|
|
let mut _27: bool; // in scope 0 at $DIR/shifts.rs:+3:20: +3:28
|
|
|
|
let mut _28: i128; // in scope 0 at $DIR/shifts.rs:+3:30: +3:38
|
|
|
|
let mut _29: i128; // in scope 0 at $DIR/shifts.rs:+3:30: +3:33
|
|
|
|
let mut _30: u128; // in scope 0 at $DIR/shifts.rs:+3:37: +3:38
|
|
|
|
let mut _31: bool; // in scope 0 at $DIR/shifts.rs:+3:30: +3:38
|
2023-03-22 03:11:25 -05:00
|
|
|
|
|
|
|
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
|
2023-03-22 03:06:19 -05:00
|
|
|
_10 = Lt(_9, const 8_u8); // scope 0 at $DIR/shifts.rs:+2:10: +2:20
|
|
|
|
assert(move _10, "attempt to shift right by `{}`, which would overflow", _9) -> [success: bb1, unwind: bb7]; // scope 0 at $DIR/shifts.rs:+2:10: +2:20
|
2023-03-22 03:11:25 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
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
|
2023-03-22 03:06:19 -05:00
|
|
|
StorageLive(_11); // scope 0 at $DIR/shifts.rs:+2:22: +2:32
|
|
|
|
StorageLive(_12); // scope 0 at $DIR/shifts.rs:+2:22: +2:27
|
|
|
|
_12 = _1; // scope 0 at $DIR/shifts.rs:+2:22: +2:27
|
|
|
|
StorageLive(_13); // scope 0 at $DIR/shifts.rs:+2:31: +2:32
|
|
|
|
_13 = _4; // scope 0 at $DIR/shifts.rs:+2:31: +2:32
|
|
|
|
_14 = Lt(_13, const 8_u32); // scope 0 at $DIR/shifts.rs:+2:22: +2:32
|
|
|
|
assert(move _14, "attempt to shift right by `{}`, which would overflow", _13) -> [success: bb2, unwind: bb7]; // scope 0 at $DIR/shifts.rs:+2:22: +2:32
|
2023-03-22 03:11:25 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
bb2: {
|
2023-03-22 03:06:19 -05:00
|
|
|
_11 = Shr(move _12, move _13); // scope 0 at $DIR/shifts.rs:+2:22: +2:32
|
2023-03-22 03:11:25 -05:00
|
|
|
StorageDead(_13); // scope 0 at $DIR/shifts.rs:+2:31: +2:32
|
2023-03-22 03:06:19 -05:00
|
|
|
StorageDead(_12); // scope 0 at $DIR/shifts.rs:+2:31: +2:32
|
|
|
|
StorageLive(_15); // scope 0 at $DIR/shifts.rs:+2:34: +2:44
|
|
|
|
StorageLive(_16); // scope 0 at $DIR/shifts.rs:+2:34: +2:39
|
|
|
|
_16 = _1; // scope 0 at $DIR/shifts.rs:+2:34: +2:39
|
|
|
|
StorageLive(_17); // scope 0 at $DIR/shifts.rs:+2:43: +2:44
|
|
|
|
_17 = _5; // scope 0 at $DIR/shifts.rs:+2:43: +2:44
|
|
|
|
_18 = Lt(_17, const 8_u128); // scope 0 at $DIR/shifts.rs:+2:34: +2:44
|
|
|
|
assert(move _18, "attempt to shift right by `{}`, which would overflow", _17) -> [success: bb3, unwind: bb7]; // scope 0 at $DIR/shifts.rs:+2:34: +2:44
|
2023-03-22 03:11:25 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
bb3: {
|
2023-03-22 03:06:19 -05:00
|
|
|
_15 = Shr(move _16, move _17); // scope 0 at $DIR/shifts.rs:+2:34: +2:44
|
|
|
|
StorageDead(_17); // scope 0 at $DIR/shifts.rs:+2:43: +2:44
|
|
|
|
StorageDead(_16); // scope 0 at $DIR/shifts.rs:+2:43: +2:44
|
|
|
|
_6 = [move _7, move _11, move _15]; // scope 0 at $DIR/shifts.rs:+2:9: +2:45
|
|
|
|
StorageDead(_15); // scope 0 at $DIR/shifts.rs:+2:44: +2:45
|
|
|
|
StorageDead(_11); // scope 0 at $DIR/shifts.rs:+2:44: +2:45
|
2023-03-22 03:11:25 -05:00
|
|
|
StorageDead(_7); // scope 0 at $DIR/shifts.rs:+2:44: +2:45
|
2023-03-22 03:06:19 -05:00
|
|
|
StorageLive(_19); // scope 0 at $DIR/shifts.rs:+3:9: +3:39
|
|
|
|
StorageLive(_20); // scope 0 at $DIR/shifts.rs:+3:10: +3:18
|
|
|
|
StorageLive(_21); // scope 0 at $DIR/shifts.rs:+3:10: +3:13
|
|
|
|
_21 = _2; // scope 0 at $DIR/shifts.rs:+3:10: +3:13
|
|
|
|
StorageLive(_22); // scope 0 at $DIR/shifts.rs:+3:17: +3:18
|
|
|
|
_22 = _3; // scope 0 at $DIR/shifts.rs:+3:17: +3:18
|
|
|
|
_23 = Lt(_22, const 128_u8); // scope 0 at $DIR/shifts.rs:+3:10: +3:18
|
|
|
|
assert(move _23, "attempt to shift left by `{}`, which would overflow", _22) -> [success: bb4, unwind: bb7]; // scope 0 at $DIR/shifts.rs:+3:10: +3:18
|
2023-03-22 03:11:25 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
bb4: {
|
2023-03-22 03:06:19 -05:00
|
|
|
_20 = Shl(move _21, move _22); // scope 0 at $DIR/shifts.rs:+3:10: +3:18
|
|
|
|
StorageDead(_22); // scope 0 at $DIR/shifts.rs:+3:17: +3:18
|
|
|
|
StorageDead(_21); // scope 0 at $DIR/shifts.rs:+3:17: +3:18
|
|
|
|
StorageLive(_24); // scope 0 at $DIR/shifts.rs:+3:20: +3:28
|
|
|
|
StorageLive(_25); // scope 0 at $DIR/shifts.rs:+3:20: +3:23
|
|
|
|
_25 = _2; // scope 0 at $DIR/shifts.rs:+3:20: +3:23
|
|
|
|
StorageLive(_26); // scope 0 at $DIR/shifts.rs:+3:27: +3:28
|
|
|
|
_26 = _4; // scope 0 at $DIR/shifts.rs:+3:27: +3:28
|
|
|
|
_27 = Lt(_26, const 128_u32); // scope 0 at $DIR/shifts.rs:+3:20: +3:28
|
|
|
|
assert(move _27, "attempt to shift left by `{}`, which would overflow", _26) -> [success: bb5, unwind: bb7]; // scope 0 at $DIR/shifts.rs:+3:20: +3:28
|
2023-03-22 03:11:25 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
bb5: {
|
2023-03-22 03:06:19 -05:00
|
|
|
_24 = Shl(move _25, move _26); // scope 0 at $DIR/shifts.rs:+3:20: +3:28
|
|
|
|
StorageDead(_26); // scope 0 at $DIR/shifts.rs:+3:27: +3:28
|
|
|
|
StorageDead(_25); // scope 0 at $DIR/shifts.rs:+3:27: +3:28
|
|
|
|
StorageLive(_28); // scope 0 at $DIR/shifts.rs:+3:30: +3:38
|
|
|
|
StorageLive(_29); // scope 0 at $DIR/shifts.rs:+3:30: +3:33
|
|
|
|
_29 = _2; // scope 0 at $DIR/shifts.rs:+3:30: +3:33
|
|
|
|
StorageLive(_30); // scope 0 at $DIR/shifts.rs:+3:37: +3:38
|
|
|
|
_30 = _5; // scope 0 at $DIR/shifts.rs:+3:37: +3:38
|
|
|
|
_31 = Lt(_30, const 128_u128); // scope 0 at $DIR/shifts.rs:+3:30: +3:38
|
|
|
|
assert(move _31, "attempt to shift left by `{}`, which would overflow", _30) -> [success: bb6, unwind: bb7]; // scope 0 at $DIR/shifts.rs:+3:30: +3:38
|
2023-03-22 03:11:25 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
bb6: {
|
2023-03-22 03:06:19 -05:00
|
|
|
_28 = Shl(move _29, move _30); // scope 0 at $DIR/shifts.rs:+3:30: +3:38
|
|
|
|
StorageDead(_30); // scope 0 at $DIR/shifts.rs:+3:37: +3:38
|
|
|
|
StorageDead(_29); // scope 0 at $DIR/shifts.rs:+3:37: +3:38
|
|
|
|
_19 = [move _20, move _24, move _28]; // scope 0 at $DIR/shifts.rs:+3:9: +3:39
|
2023-03-22 03:11:25 -05:00
|
|
|
StorageDead(_28); // scope 0 at $DIR/shifts.rs:+3:38: +3:39
|
2023-03-22 03:06:19 -05:00
|
|
|
StorageDead(_24); // scope 0 at $DIR/shifts.rs:+3:38: +3:39
|
|
|
|
StorageDead(_20); // scope 0 at $DIR/shifts.rs:+3:38: +3:39
|
|
|
|
_0 = (move _6, move _19); // scope 0 at $DIR/shifts.rs:+1:5: +4:6
|
|
|
|
StorageDead(_19); // scope 0 at $DIR/shifts.rs:+4:5: +4:6
|
2023-03-22 03:11:25 -05:00
|
|
|
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
|
|
|
|
}
|
|
|
|
}
|