]> git.lizzy.rs Git - rust.git/blob - src/test/mir-opt/exponential_or.match_tuple.SimplifyCfg-initial.after.mir
Fix diagnostic issue when using FakeReads in closures
[rust.git] / src / test / mir-opt / exponential_or.match_tuple.SimplifyCfg-initial.after.mir
1 // MIR for `match_tuple` after SimplifyCfg-initial
2
3 fn match_tuple(_1: (u32, bool, Option<i32>, u32)) -> u32 {
4     debug x => _1;                       // in scope 0 at $DIR/exponential-or.rs:4:16: 4:17
5     let mut _0: u32;                     // return place in scope 0 at $DIR/exponential-or.rs:4:53: 4:56
6     let mut _2: isize;                   // in scope 0 at $DIR/exponential-or.rs:6:37: 6:48
7     let mut _3: bool;                    // in scope 0 at $DIR/exponential-or.rs:6:70: 6:77
8     let mut _4: bool;                    // in scope 0 at $DIR/exponential-or.rs:6:70: 6:77
9     let mut _5: bool;                    // in scope 0 at $DIR/exponential-or.rs:6:62: 6:67
10     let mut _6: bool;                    // in scope 0 at $DIR/exponential-or.rs:6:62: 6:67
11     let _7: u32;                         // in scope 0 at $DIR/exponential-or.rs:6:10: 6:21
12     let _8: u32;                         // in scope 0 at $DIR/exponential-or.rs:6:57: 6:78
13     let mut _9: u32;                     // in scope 0 at $DIR/exponential-or.rs:6:83: 6:84
14     let mut _10: u32;                    // in scope 0 at $DIR/exponential-or.rs:6:87: 6:88
15     scope 1 {
16         debug y => _7;                   // in scope 1 at $DIR/exponential-or.rs:6:10: 6:21
17         debug z => _8;                   // in scope 1 at $DIR/exponential-or.rs:6:57: 6:78
18     }
19
20     bb0: {
21         FakeRead(ForMatchedPlace(None), _1); // scope 0 at $DIR/exponential-or.rs:5:11: 5:12
22         switchInt((_1.0: u32)) -> [1_u32: bb2, 4_u32: bb2, otherwise: bb1]; // scope 0 at $DIR/exponential-or.rs:6:15: 6:16
23     }
24
25     bb1: {
26         _0 = const 0_u32;                // scope 0 at $DIR/exponential-or.rs:7:14: 7:15
27         goto -> bb10;                    // scope 0 at $DIR/exponential-or.rs:5:5: 8:6
28     }
29
30     bb2: {
31         _2 = discriminant((_1.2: std::option::Option<i32>)); // scope 0 at $DIR/exponential-or.rs:6:37: 6:48
32         switchInt(move _2) -> [0_isize: bb4, 1_isize: bb3, otherwise: bb1]; // scope 0 at $DIR/exponential-or.rs:6:37: 6:48
33     }
34
35     bb3: {
36         switchInt((((_1.2: std::option::Option<i32>) as Some).0: i32)) -> [1_i32: bb4, 8_i32: bb4, otherwise: bb1]; // scope 0 at $DIR/exponential-or.rs:6:42: 6:43
37     }
38
39     bb4: {
40         _5 = Le(const 6_u32, (_1.3: u32)); // scope 0 at $DIR/exponential-or.rs:6:62: 6:67
41         switchInt(move _5) -> [false: bb6, otherwise: bb5]; // scope 0 at $DIR/exponential-or.rs:6:62: 6:67
42     }
43
44     bb5: {
45         _6 = Le((_1.3: u32), const 9_u32); // scope 0 at $DIR/exponential-or.rs:6:62: 6:67
46         switchInt(move _6) -> [false: bb6, otherwise: bb8]; // scope 0 at $DIR/exponential-or.rs:6:62: 6:67
47     }
48
49     bb6: {
50         _3 = Le(const 13_u32, (_1.3: u32)); // scope 0 at $DIR/exponential-or.rs:6:70: 6:77
51         switchInt(move _3) -> [false: bb1, otherwise: bb7]; // scope 0 at $DIR/exponential-or.rs:6:70: 6:77
52     }
53
54     bb7: {
55         _4 = Le((_1.3: u32), const 16_u32); // scope 0 at $DIR/exponential-or.rs:6:70: 6:77
56         switchInt(move _4) -> [false: bb1, otherwise: bb8]; // scope 0 at $DIR/exponential-or.rs:6:70: 6:77
57     }
58
59     bb8: {
60         falseEdge -> [real: bb9, imaginary: bb1]; // scope 0 at $DIR/exponential-or.rs:6:9: 6:79
61     }
62
63     bb9: {
64         StorageLive(_7);                 // scope 0 at $DIR/exponential-or.rs:6:10: 6:21
65         _7 = (_1.0: u32);                // scope 0 at $DIR/exponential-or.rs:6:10: 6:21
66         StorageLive(_8);                 // scope 0 at $DIR/exponential-or.rs:6:57: 6:78
67         _8 = (_1.3: u32);                // scope 0 at $DIR/exponential-or.rs:6:57: 6:78
68         StorageLive(_9);                 // scope 1 at $DIR/exponential-or.rs:6:83: 6:84
69         _9 = _7;                         // scope 1 at $DIR/exponential-or.rs:6:83: 6:84
70         StorageLive(_10);                // scope 1 at $DIR/exponential-or.rs:6:87: 6:88
71         _10 = _8;                        // scope 1 at $DIR/exponential-or.rs:6:87: 6:88
72         _0 = BitXor(move _9, move _10);  // scope 1 at $DIR/exponential-or.rs:6:83: 6:88
73         StorageDead(_10);                // scope 1 at $DIR/exponential-or.rs:6:87: 6:88
74         StorageDead(_9);                 // scope 1 at $DIR/exponential-or.rs:6:87: 6:88
75         StorageDead(_8);                 // scope 0 at $DIR/exponential-or.rs:6:87: 6:88
76         StorageDead(_7);                 // scope 0 at $DIR/exponential-or.rs:6:87: 6:88
77         goto -> bb10;                    // scope 0 at $DIR/exponential-or.rs:5:5: 8:6
78     }
79
80     bb10: {
81         return;                          // scope 0 at $DIR/exponential-or.rs:9:2: 9:2
82     }
83 }