summaryrefslogtreecommitdiffstats
path: root/tests/mir-opt/dataflow-const-prop/checked.main.DataflowConstProp.diff
blob: a4ebd0c8c18f0a11952c06e563021901d0429a1d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
- // MIR for `main` before DataflowConstProp
+ // MIR for `main` after DataflowConstProp
  
  fn main() -> () {
      let mut _0: ();                      // return place in scope 0 at $DIR/checked.rs:+0:11: +0:11
      let _1: i32;                         // in scope 0 at $DIR/checked.rs:+1:9: +1:10
      let mut _4: i32;                     // in scope 0 at $DIR/checked.rs:+3:13: +3:14
      let mut _5: i32;                     // in scope 0 at $DIR/checked.rs:+3:17: +3:18
      let mut _6: (i32, bool);             // in scope 0 at $DIR/checked.rs:+3:13: +3:18
      let mut _9: i32;                     // in scope 0 at $DIR/checked.rs:+6:13: +6:14
      let mut _10: (i32, bool);            // in scope 0 at $DIR/checked.rs:+6:13: +6:18
      scope 1 {
          debug a => _1;                   // in scope 1 at $DIR/checked.rs:+1:9: +1:10
          let _2: i32;                     // in scope 1 at $DIR/checked.rs:+2:9: +2:10
          scope 2 {
              debug b => _2;               // in scope 2 at $DIR/checked.rs:+2:9: +2:10
              let _3: i32;                 // in scope 2 at $DIR/checked.rs:+3:9: +3:10
              scope 3 {
                  debug c => _3;           // in scope 3 at $DIR/checked.rs:+3:9: +3:10
                  let _7: i32;             // in scope 3 at $DIR/checked.rs:+5:9: +5:10
                  scope 4 {
                      debug d => _7;       // in scope 4 at $DIR/checked.rs:+5:9: +5:10
                      let _8: i32;         // in scope 4 at $DIR/checked.rs:+6:9: +6:10
                      scope 5 {
                          debug e => _8;   // in scope 5 at $DIR/checked.rs:+6:9: +6:10
                      }
                  }
              }
          }
      }
  
      bb0: {
          StorageLive(_1);                 // scope 0 at $DIR/checked.rs:+1:9: +1:10
          _1 = const 1_i32;                // scope 0 at $DIR/checked.rs:+1:13: +1:14
          StorageLive(_2);                 // scope 1 at $DIR/checked.rs:+2:9: +2:10
          _2 = const 2_i32;                // scope 1 at $DIR/checked.rs:+2:13: +2:14
          StorageLive(_3);                 // scope 2 at $DIR/checked.rs:+3:9: +3:10
          StorageLive(_4);                 // scope 2 at $DIR/checked.rs:+3:13: +3:14
-         _4 = _1;                         // scope 2 at $DIR/checked.rs:+3:13: +3:14
+         _4 = const 1_i32;                // scope 2 at $DIR/checked.rs:+3:13: +3:14
          StorageLive(_5);                 // scope 2 at $DIR/checked.rs:+3:17: +3:18
-         _5 = _2;                         // scope 2 at $DIR/checked.rs:+3:17: +3:18
-         _6 = CheckedAdd(_4, _5);         // scope 2 at $DIR/checked.rs:+3:13: +3:18
-         assert(!move (_6.1: bool), "attempt to compute `{} + {}`, which would overflow", move _4, move _5) -> bb1; // scope 2 at $DIR/checked.rs:+3:13: +3:18
+         _5 = const 2_i32;                // scope 2 at $DIR/checked.rs:+3:17: +3:18
+         _6 = CheckedAdd(const 1_i32, const 2_i32); // scope 2 at $DIR/checked.rs:+3:13: +3:18
+         assert(!const false, "attempt to compute `{} + {}`, which would overflow", const 1_i32, const 2_i32) -> bb1; // scope 2 at $DIR/checked.rs:+3:13: +3:18
      }
  
      bb1: {
-         _3 = move (_6.0: i32);           // scope 2 at $DIR/checked.rs:+3:13: +3:18
+         _3 = const 3_i32;                // scope 2 at $DIR/checked.rs:+3:13: +3:18
          StorageDead(_5);                 // scope 2 at $DIR/checked.rs:+3:17: +3:18
          StorageDead(_4);                 // scope 2 at $DIR/checked.rs:+3:17: +3:18
          StorageLive(_7);                 // scope 3 at $DIR/checked.rs:+5:9: +5:10
          _7 = const _;                    // scope 3 at $DIR/checked.rs:+5:13: +5:21
          StorageLive(_8);                 // scope 4 at $DIR/checked.rs:+6:9: +6:10
          StorageLive(_9);                 // scope 4 at $DIR/checked.rs:+6:13: +6:14
-         _9 = _7;                         // scope 4 at $DIR/checked.rs:+6:13: +6:14
-         _10 = CheckedAdd(_9, const 1_i32); // scope 4 at $DIR/checked.rs:+6:13: +6:18
-         assert(!move (_10.1: bool), "attempt to compute `{} + {}`, which would overflow", move _9, const 1_i32) -> bb2; // scope 4 at $DIR/checked.rs:+6:13: +6:18
+         _9 = const i32::MAX;             // scope 4 at $DIR/checked.rs:+6:13: +6:14
+         _10 = CheckedAdd(const i32::MAX, const 1_i32); // scope 4 at $DIR/checked.rs:+6:13: +6:18
+         assert(!move (_10.1: bool), "attempt to compute `{} + {}`, which would overflow", const i32::MAX, const 1_i32) -> bb2; // scope 4 at $DIR/checked.rs:+6:13: +6:18
      }
  
      bb2: {
-         _8 = move (_10.0: i32);          // scope 4 at $DIR/checked.rs:+6:13: +6:18
+         _8 = const i32::MIN;             // scope 4 at $DIR/checked.rs:+6:13: +6:18
          StorageDead(_9);                 // scope 4 at $DIR/checked.rs:+6:17: +6:18
          _0 = const ();                   // scope 0 at $DIR/checked.rs:+0:11: +7:2
          StorageDead(_8);                 // scope 4 at $DIR/checked.rs:+7:1: +7:2
          StorageDead(_7);                 // scope 3 at $DIR/checked.rs:+7:1: +7:2
          StorageDead(_3);                 // scope 2 at $DIR/checked.rs:+7:1: +7:2
          StorageDead(_2);                 // scope 1 at $DIR/checked.rs:+7:1: +7:2
          StorageDead(_1);                 // scope 0 at $DIR/checked.rs:+7:1: +7:2
          return;                          // scope 0 at $DIR/checked.rs:+7:2: +7:2
      }
  }