2023-01-14 12:01:27 +00:00
|
|
|
- // MIR for `outer` before Inline
|
|
|
|
+ // MIR for `outer` after Inline
|
|
|
|
|
|
|
|
fn outer() -> usize {
|
2023-06-06 09:47:00 -04: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 12:01:27 +00:00
|
|
|
+ scope 2 {
|
2023-06-06 09:47:00 -04:00
|
|
|
+ debug buffer => const _;
|
2023-01-14 12:01:27 +00:00
|
|
|
+ scope 3 {
|
2023-06-06 09:47:00 -04:00
|
|
|
+ debug index => _0;
|
2023-01-14 12:01:27 +00:00
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
|
|
|
|
bb0: {
|
2023-06-06 09:47:00 -04:00
|
|
|
- _0 = inner() -> bb1;
|
|
|
|
+ StorageLive(_1);
|
|
|
|
+ _1 = const _;
|
|
|
|
+ _0 = index() -> bb1;
|
2023-01-14 12:01:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
bb1: {
|
2023-06-06 09:47:00 -04: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) -> bb2;
|
2023-01-14 12:01:27 +00:00
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ bb2: {
|
2023-06-06 09:47:00 -04:00
|
|
|
+ _3 = (*_1)[_0];
|
|
|
|
+ switchInt(move _3) -> [0: bb3, otherwise: bb4];
|
2023-01-14 12:01:27 +00:00
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ bb3: {
|
2023-06-06 09:47:00 -04:00
|
|
|
+ _0 = const 0_usize;
|
|
|
|
+ goto -> bb4;
|
2023-01-14 12:01:27 +00:00
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ bb4: {
|
2023-06-06 09:47:00 -04:00
|
|
|
+ StorageDead(_3);
|
|
|
|
+ StorageDead(_1);
|
|
|
|
return;
|
2023-01-14 12:01:27 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|