]> git.lizzy.rs Git - rust.git/blob - src/test/mir-opt/storage_ranges.main.nll.0.mir
Rollup merge of #100247 - cjgillot:verify-dyn-trait-alias-defaults, r=lcnr
[rust.git] / src / test / mir-opt / storage_ranges.main.nll.0.mir
1 // MIR for `main` 0 nll
2
3 | Free Region Mapping
4 | '_#0r | Global | ['_#0r, '_#1r]
5 | '_#1r | Local | ['_#1r]
6 |
7 | Inferred Region Values
8 | '_#0r | U0 | {bb0[0..=22], '_#0r, '_#1r}
9 | '_#1r | U0 | {bb0[0..=22], '_#1r}
10 | '_#2r | U0 | {}
11 | '_#3r | U0 | {bb0[10..=11]}
12 | '_#4r | U0 | {bb0[11]}
13 |
14 | Inference Constraints
15 | '_#0r live at {bb0[0..=22]}
16 | '_#1r live at {bb0[0..=22]}
17 | '_#3r live at {bb0[10]}
18 | '_#4r live at {bb0[11]}
19 | '_#3r: '_#4r due to Assignment at Single(bb0[10]) ($DIR/storage_ranges.rs:6:17: 6:25 (#0)
20 |
21 fn main() -> () {
22     let mut _0: ();                      // return place in scope 0 at $DIR/storage_ranges.rs:+0:11: +0:11
23     let _1: i32;                         // in scope 0 at $DIR/storage_ranges.rs:+1:9: +1:10
24     let _2: ();                          // in scope 0 at $DIR/storage_ranges.rs:+2:5: +4:6
25     let _4: std::option::Option<i32>;    // in scope 0 at $DIR/storage_ranges.rs:+3:18: +3:25
26     let mut _5: i32;                     // in scope 0 at $DIR/storage_ranges.rs:+3:23: +3:24
27     scope 1 {
28         debug a => _1;                   // in scope 1 at $DIR/storage_ranges.rs:+1:9: +1:10
29         let _3: &std::option::Option<i32>; // in scope 1 at $DIR/storage_ranges.rs:+3:13: +3:14
30         let _6: i32;                     // in scope 1 at $DIR/storage_ranges.rs:+5:9: +5:10
31         scope 2 {
32             debug b => _3;               // in scope 2 at $DIR/storage_ranges.rs:+3:13: +3:14
33         }
34         scope 3 {
35             debug c => _6;               // in scope 3 at $DIR/storage_ranges.rs:+5:9: +5:10
36         }
37     }
38
39     bb0: {
40         StorageLive(_1);                 // scope 0 at $DIR/storage_ranges.rs:+1:9: +1:10
41         _1 = const 0_i32;                // scope 0 at $DIR/storage_ranges.rs:+1:13: +1:14
42         FakeRead(ForLet(None), _1);      // scope 0 at $DIR/storage_ranges.rs:+1:9: +1:10
43         StorageLive(_2);                 // scope 1 at $DIR/storage_ranges.rs:+2:5: +4:6
44         StorageLive(_3);                 // scope 1 at $DIR/storage_ranges.rs:+3:13: +3:14
45         StorageLive(_4);                 // scope 1 at $DIR/storage_ranges.rs:+3:18: +3:25
46         StorageLive(_5);                 // scope 1 at $DIR/storage_ranges.rs:+3:23: +3:24
47         _5 = _1;                         // scope 1 at $DIR/storage_ranges.rs:+3:23: +3:24
48         _4 = Option::<i32>::Some(move _5); // scope 1 at $DIR/storage_ranges.rs:+3:18: +3:25
49         StorageDead(_5);                 // scope 1 at $DIR/storage_ranges.rs:+3:24: +3:25
50         _3 = &_4;                        // scope 1 at $DIR/storage_ranges.rs:+3:17: +3:25
51         FakeRead(ForLet(None), _3);      // scope 1 at $DIR/storage_ranges.rs:+3:13: +3:14
52         _2 = const ();                   // scope 1 at $DIR/storage_ranges.rs:+2:5: +4:6
53         StorageDead(_4);                 // scope 1 at $DIR/storage_ranges.rs:+4:5: +4:6
54         StorageDead(_3);                 // scope 1 at $DIR/storage_ranges.rs:+4:5: +4:6
55         StorageDead(_2);                 // scope 1 at $DIR/storage_ranges.rs:+4:5: +4:6
56         StorageLive(_6);                 // scope 1 at $DIR/storage_ranges.rs:+5:9: +5:10
57         _6 = const 1_i32;                // scope 1 at $DIR/storage_ranges.rs:+5:13: +5:14
58         FakeRead(ForLet(None), _6);      // scope 1 at $DIR/storage_ranges.rs:+5:9: +5:10
59         _0 = const ();                   // scope 0 at $DIR/storage_ranges.rs:+0:11: +6:2
60         StorageDead(_6);                 // scope 1 at $DIR/storage_ranges.rs:+6:1: +6:2
61         StorageDead(_1);                 // scope 0 at $DIR/storage_ranges.rs:+6:1: +6:2
62         return;                          // scope 0 at $DIR/storage_ranges.rs:+6:2: +6:2
63     }
64 }