2023-01-14 06:01:27 -06:00
|
|
|
- // MIR for `outer` before Inline
|
|
|
|
+ // MIR for `outer` after Inline
|
|
|
|
|
|
|
|
fn outer() -> usize {
|
2023-06-06 08:47:00 -05:00
|
|
|
let mut _0: usize;
|
|
|
|
+ scope 1 (inlined inner) {
|
|
|
|
+ let mut _1: &[bool; 1];
|
|
|
|
+ let mut _2: bool;
|
|
|
|
+ let mut _3: bool;
|
2023-01-14 06:01:27 -06:00
|
|
|
+ scope 2 {
|
2024-06-10 01:47:41 -05:00
|
|
|
+ debug buffer => _1;
|
2023-01-14 06:01:27 -06:00
|
|
|
+ scope 3 {
|
2023-06-06 08:47:00 -05:00
|
|
|
+ debug index => _0;
|
2023-01-14 06:01:27 -06:00
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
|
|
|
|
bb0: {
|
2023-06-06 08:47:00 -05:00
|
|
|
- _0 = inner() -> [return: bb1, unwind unreachable];
|
|
|
|
+ StorageLive(_1);
|
2023-10-04 12:50:03 -05:00
|
|
|
+ StorageLive(_2);
|
2024-03-10 08:05:11 -05:00
|
|
|
+ _1 = const inner::promoted[0];
|
2023-06-06 08:47:00 -05:00
|
|
|
+ _0 = index() -> [return: bb1, unwind unreachable];
|
2023-01-14 06:01:27 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
bb1: {
|
2023-06-06 08:47:00 -05:00
|
|
|
+ StorageLive(_3);
|
|
|
|
+ _2 = Lt(_0, const 1_usize);
|
|
|
|
+ assert(move _2, "index out of bounds: the length is {} but the index is {}", const 1_usize, _0) -> [success: bb2, unwind unreachable];
|
2023-01-14 06:01:27 -06:00
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ bb2: {
|
2023-06-06 08:47:00 -05:00
|
|
|
+ _3 = (*_1)[_0];
|
|
|
|
+ switchInt(move _3) -> [0: bb3, otherwise: bb4];
|
2023-01-14 06:01:27 -06:00
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ bb3: {
|
2023-06-06 08:47:00 -05:00
|
|
|
+ _0 = const 0_usize;
|
|
|
|
+ goto -> bb4;
|
2023-01-14 06:01:27 -06:00
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ bb4: {
|
2023-06-06 08:47:00 -05:00
|
|
|
+ StorageDead(_3);
|
2023-10-04 12:50:03 -05:00
|
|
|
+ StorageDead(_2);
|
2023-06-06 08:47:00 -05:00
|
|
|
+ StorageDead(_1);
|
|
|
|
return;
|
2023-01-14 06:01:27 -06:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|