| // MIR for `match_tuple` after SimplifyCfg-initial |
| |
| fn match_tuple(_1: (u32, bool, Option<i32>, u32)) -> u32 { |
| debug x => _1; // in scope 0 at $DIR/exponential-or.rs:4:16: 4:17 |
| let mut _0: u32; // return place in scope 0 at $DIR/exponential-or.rs:4:53: 4:56 |
| let mut _2: isize; // in scope 0 at $DIR/exponential-or.rs:6:37: 6:48 |
| let mut _3: bool; // in scope 0 at $DIR/exponential-or.rs:6:70: 6:77 |
| let mut _4: bool; // in scope 0 at $DIR/exponential-or.rs:6:70: 6:77 |
| let mut _5: bool; // in scope 0 at $DIR/exponential-or.rs:6:62: 6:67 |
| let mut _6: bool; // in scope 0 at $DIR/exponential-or.rs:6:62: 6:67 |
| let _7: u32; // in scope 0 at $DIR/exponential-or.rs:6:10: 6:21 |
| let _8: u32; // in scope 0 at $DIR/exponential-or.rs:6:57: 6:78 |
| let mut _9: u32; // in scope 0 at $DIR/exponential-or.rs:6:83: 6:84 |
| let mut _10: u32; // in scope 0 at $DIR/exponential-or.rs:6:87: 6:88 |
| scope 1 { |
| debug y => _7; // in scope 1 at $DIR/exponential-or.rs:6:10: 6:21 |
| debug z => _8; // in scope 1 at $DIR/exponential-or.rs:6:57: 6:78 |
| } |
| |
| bb0: { |
| FakeRead(ForMatchedPlace(None), _1); // scope 0 at $DIR/exponential-or.rs:5:11: 5:12 |
| switchInt((_1.0: u32)) -> [1_u32: bb2, 4_u32: bb2, otherwise: bb1]; // scope 0 at $DIR/exponential-or.rs:6:15: 6:16 |
| } |
| |
| bb1: { |
| _0 = const 0_u32; // scope 0 at $DIR/exponential-or.rs:7:14: 7:15 |
| goto -> bb10; // scope 0 at $DIR/exponential-or.rs:5:5: 8:6 |
| } |
| |
| bb2: { |
| _2 = discriminant((_1.2: std::option::Option<i32>)); // scope 0 at $DIR/exponential-or.rs:6:37: 6:48 |
| switchInt(move _2) -> [0_isize: bb4, 1_isize: bb3, otherwise: bb1]; // scope 0 at $DIR/exponential-or.rs:6:37: 6:48 |
| } |
| |
| bb3: { |
| 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 |
| } |
| |
| bb4: { |
| _5 = Le(const 6_u32, (_1.3: u32)); // scope 0 at $DIR/exponential-or.rs:6:62: 6:67 |
| switchInt(move _5) -> [false: bb6, otherwise: bb5]; // scope 0 at $DIR/exponential-or.rs:6:62: 6:67 |
| } |
| |
| bb5: { |
| _6 = Le((_1.3: u32), const 9_u32); // scope 0 at $DIR/exponential-or.rs:6:62: 6:67 |
| switchInt(move _6) -> [false: bb6, otherwise: bb8]; // scope 0 at $DIR/exponential-or.rs:6:62: 6:67 |
| } |
| |
| bb6: { |
| _3 = Le(const 13_u32, (_1.3: u32)); // scope 0 at $DIR/exponential-or.rs:6:70: 6:77 |
| switchInt(move _3) -> [false: bb1, otherwise: bb7]; // scope 0 at $DIR/exponential-or.rs:6:70: 6:77 |
| } |
| |
| bb7: { |
| _4 = Le((_1.3: u32), const 16_u32); // scope 0 at $DIR/exponential-or.rs:6:70: 6:77 |
| switchInt(move _4) -> [false: bb1, otherwise: bb8]; // scope 0 at $DIR/exponential-or.rs:6:70: 6:77 |
| } |
| |
| bb8: { |
| falseEdge -> [real: bb9, imaginary: bb1]; // scope 0 at $DIR/exponential-or.rs:6:9: 6:79 |
| } |
| |
| bb9: { |
| StorageLive(_7); // scope 0 at $DIR/exponential-or.rs:6:10: 6:21 |
| _7 = (_1.0: u32); // scope 0 at $DIR/exponential-or.rs:6:10: 6:21 |
| StorageLive(_8); // scope 0 at $DIR/exponential-or.rs:6:57: 6:78 |
| _8 = (_1.3: u32); // scope 0 at $DIR/exponential-or.rs:6:57: 6:78 |
| StorageLive(_9); // scope 1 at $DIR/exponential-or.rs:6:83: 6:84 |
| _9 = _7; // scope 1 at $DIR/exponential-or.rs:6:83: 6:84 |
| StorageLive(_10); // scope 1 at $DIR/exponential-or.rs:6:87: 6:88 |
| _10 = _8; // scope 1 at $DIR/exponential-or.rs:6:87: 6:88 |
| _0 = BitXor(move _9, move _10); // scope 1 at $DIR/exponential-or.rs:6:83: 6:88 |
| StorageDead(_10); // scope 1 at $DIR/exponential-or.rs:6:87: 6:88 |
| StorageDead(_9); // scope 1 at $DIR/exponential-or.rs:6:87: 6:88 |
| StorageDead(_8); // scope 0 at $DIR/exponential-or.rs:6:87: 6:88 |
| StorageDead(_7); // scope 0 at $DIR/exponential-or.rs:6:87: 6:88 |
| goto -> bb10; // scope 0 at $DIR/exponential-or.rs:5:5: 8:6 |
| } |
| |
| bb10: { |
| return; // scope 0 at $DIR/exponential-or.rs:9:2: 9:2 |
| } |
| } |