rust/tests/mir-opt/storage_ranges.main.nll.0.mir

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

64 lines
3.5 KiB
Rust
Raw Normal View History

2020-04-02 21:09:01 +00:00
// MIR for `main` 0 nll
| Free Region Mapping
2023-04-22 00:08:38 +00:00
| '?0 | Global | ['?0, '?1]
| '?1 | Local | ['?1]
2020-04-02 21:09:01 +00:00
|
| Inferred Region Values
2023-04-22 00:08:38 +00:00
| '?0 | U0 | {bb0[0..=22], '?0, '?1}
| '?1 | U0 | {bb0[0..=22], '?1}
| '?2 | U0 | {bb0[10..=11]}
| '?3 | U0 | {bb0[11]}
2020-04-02 21:09:01 +00:00
|
| Inference Constraints
2023-04-22 00:08:38 +00:00
| '?0 live at {bb0[0..=22]}
| '?1 live at {bb0[0..=22]}
| '?2 live at {bb0[10]}
| '?3 live at {bb0[11]}
| '?2: '?3 due to Assignment at Single(bb0[10]) ($DIR/storage_ranges.rs:6:17: 6:25 (#0)
2020-04-02 21:09:01 +00:00
|
fn main() -> () {
2022-07-27 20:47:42 +02:00
let mut _0: (); // return place in scope 0 at $DIR/storage_ranges.rs:+0:11: +0:11
let _1: i32; // in scope 0 at $DIR/storage_ranges.rs:+1:9: +1:10
let _2: (); // in scope 0 at $DIR/storage_ranges.rs:+2:5: +4:6
let _4: std::option::Option<i32>; // in scope 0 at $DIR/storage_ranges.rs:+3:18: +3:25
let mut _5: i32; // in scope 0 at $DIR/storage_ranges.rs:+3:23: +3:24
2020-04-02 21:09:01 +00:00
scope 1 {
2022-07-27 20:47:42 +02:00
debug a => _1; // in scope 1 at $DIR/storage_ranges.rs:+1:9: +1:10
let _3: &std::option::Option<i32>; // in scope 1 at $DIR/storage_ranges.rs:+3:13: +3:14
let _6: i32; // in scope 1 at $DIR/storage_ranges.rs:+5:9: +5:10
2020-04-02 21:09:01 +00:00
scope 2 {
2022-07-27 20:47:42 +02:00
debug b => _3; // in scope 2 at $DIR/storage_ranges.rs:+3:13: +3:14
2020-04-02 21:09:01 +00:00
}
scope 3 {
2022-07-27 20:47:42 +02:00
debug c => _6; // in scope 3 at $DIR/storage_ranges.rs:+5:9: +5:10
2020-04-02 21:09:01 +00:00
}
}
bb0: {
2022-07-27 20:47:42 +02:00
StorageLive(_1); // scope 0 at $DIR/storage_ranges.rs:+1:9: +1:10
_1 = const 0_i32; // scope 0 at $DIR/storage_ranges.rs:+1:13: +1:14
FakeRead(ForLet(None), _1); // scope 0 at $DIR/storage_ranges.rs:+1:9: +1:10
StorageLive(_2); // scope 1 at $DIR/storage_ranges.rs:+2:5: +4:6
StorageLive(_3); // scope 1 at $DIR/storage_ranges.rs:+3:13: +3:14
StorageLive(_4); // scope 1 at $DIR/storage_ranges.rs:+3:18: +3:25
StorageLive(_5); // scope 1 at $DIR/storage_ranges.rs:+3:23: +3:24
_5 = _1; // scope 1 at $DIR/storage_ranges.rs:+3:23: +3:24
_4 = Option::<i32>::Some(move _5); // scope 1 at $DIR/storage_ranges.rs:+3:18: +3:25
StorageDead(_5); // scope 1 at $DIR/storage_ranges.rs:+3:24: +3:25
_3 = &_4; // scope 1 at $DIR/storage_ranges.rs:+3:17: +3:25
FakeRead(ForLet(None), _3); // scope 1 at $DIR/storage_ranges.rs:+3:13: +3:14
_2 = const (); // scope 1 at $DIR/storage_ranges.rs:+2:5: +4:6
StorageDead(_4); // scope 1 at $DIR/storage_ranges.rs:+4:5: +4:6
StorageDead(_3); // scope 1 at $DIR/storage_ranges.rs:+4:5: +4:6
StorageDead(_2); // scope 1 at $DIR/storage_ranges.rs:+4:5: +4:6
StorageLive(_6); // scope 1 at $DIR/storage_ranges.rs:+5:9: +5:10
_6 = const 1_i32; // scope 1 at $DIR/storage_ranges.rs:+5:13: +5:14
FakeRead(ForLet(None), _6); // scope 1 at $DIR/storage_ranges.rs:+5:9: +5:10
_0 = const (); // scope 0 at $DIR/storage_ranges.rs:+0:11: +6:2
StorageDead(_6); // scope 1 at $DIR/storage_ranges.rs:+6:1: +6:2
StorageDead(_1); // scope 0 at $DIR/storage_ranges.rs:+6:1: +6:2
return; // scope 0 at $DIR/storage_ranges.rs:+6:2: +6:2
2020-04-02 21:09:01 +00:00
}
}