summaryrefslogtreecommitdiffstats
path: root/tests/mir-opt/dataflow-const-prop/checked.main.DataflowConstProp.panic-unwind.diff
blob: aa7e404eb9f5037c1687899b19a5e1368a65301d (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
81
82
83
84
85
86
87
88
- // MIR for `main` before DataflowConstProp
+ // MIR for `main` after DataflowConstProp
  
  fn main() -> () {
      let mut _0: ();
      let _1: i32;
      let mut _4: i32;
      let mut _5: i32;
      let mut _6: (i32, bool);
      let mut _9: i32;
      let mut _10: (i32, bool);
      scope 1 {
          debug a => _1;
          let _2: i32;
          scope 2 {
              debug b => _2;
              let _3: i32;
              scope 3 {
                  debug c => _3;
                  let _7: i32;
                  scope 4 {
                      debug d => _7;
                      let _8: i32;
                      scope 5 {
                          debug e => _8;
                      }
                  }
              }
          }
      }
  
      bb0: {
          StorageLive(_1);
          _1 = const 1_i32;
          StorageLive(_2);
          _2 = const 2_i32;
          StorageLive(_3);
          StorageLive(_4);
-         _4 = _1;
+         _4 = const 1_i32;
          StorageLive(_5);
-         _5 = _2;
-         _6 = CheckedAdd(_4, _5);
-         assert(!move (_6.1: bool), "attempt to compute `{} + {}`, which would overflow", move _4, move _5) -> [success: bb1, unwind continue];
+         _5 = const 2_i32;
+         _6 = const (3_i32, false);
+         assert(!const false, "attempt to compute `{} + {}`, which would overflow", const 1_i32, const 2_i32) -> [success: bb1, unwind continue];
      }
  
      bb1: {
-         _3 = move (_6.0: i32);
+         _3 = const 3_i32;
          StorageDead(_5);
          StorageDead(_4);
          StorageLive(_7);
          _7 = const _;
          StorageLive(_8);
          StorageLive(_9);
-         _9 = _7;
-         _10 = CheckedAdd(_9, const 1_i32);
-         assert(!move (_10.1: bool), "attempt to compute `{} + {}`, which would overflow", move _9, const 1_i32) -> [success: bb2, unwind continue];
+         _9 = const i32::MAX;
+         _10 = const (i32::MIN, true);
+         assert(!const true, "attempt to compute `{} + {}`, which would overflow", const i32::MAX, const 1_i32) -> [success: bb2, unwind continue];
      }
  
      bb2: {
-         _8 = move (_10.0: i32);
+         _8 = const i32::MIN;
          StorageDead(_9);
          _0 = const ();
          StorageDead(_8);
          StorageDead(_7);
          StorageDead(_3);
          StorageDead(_2);
          StorageDead(_1);
          return;
      }
+ }
+ 
+ ALLOC0 (size: 8, align: 4) {
+     00 00 00 80 01 __ __ __                         │ .....░░░
+ }
+ 
+ ALLOC1 (size: 8, align: 4) {
+     03 00 00 00 00 __ __ __                         │ .....░░░
  }