summaryrefslogtreecommitdiffstats
path: root/tests/mir-opt/issue_41110.main.ElaborateDrops.diff
blob: 7ac75b51a370f67929c23de185cd4181f81955d6 (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
- // MIR for `main` before ElaborateDrops
+ // MIR for `main` after ElaborateDrops
  
  fn main() -> () {
      let mut _0: ();                      // return place in scope 0 at $DIR/issue_41110.rs:+0:11: +0:11
      let _1: ();                          // in scope 0 at $DIR/issue_41110.rs:+1:9: +1:10
      let mut _2: S;                       // in scope 0 at $DIR/issue_41110.rs:+1:13: +1:14
      let mut _3: S;                       // in scope 0 at $DIR/issue_41110.rs:+1:21: +1:27
      let mut _4: S;                       // in scope 0 at $DIR/issue_41110.rs:+1:21: +1:22
+     let mut _5: bool;                    // in scope 0 at $DIR/issue_41110.rs:+1:27: +1:28
      scope 1 {
          debug x => _1;                   // in scope 1 at $DIR/issue_41110.rs:+1:9: +1:10
      }
  
      bb0: {
+         _5 = const false;                // scope 0 at $DIR/issue_41110.rs:+1:9: +1:10
          StorageLive(_1);                 // scope 0 at $DIR/issue_41110.rs:+1:9: +1:10
          StorageLive(_2);                 // scope 0 at $DIR/issue_41110.rs:+1:13: +1:14
+         _5 = const true;                 // scope 0 at $DIR/issue_41110.rs:+1:13: +1:14
          _2 = S;                          // scope 0 at $DIR/issue_41110.rs:+1:13: +1:14
          StorageLive(_3);                 // scope 0 at $DIR/issue_41110.rs:+1:21: +1:27
          StorageLive(_4);                 // scope 0 at $DIR/issue_41110.rs:+1:21: +1:22
          _4 = S;                          // scope 0 at $DIR/issue_41110.rs:+1:21: +1:22
          _3 = S::id(move _4) -> [return: bb1, unwind: bb4]; // scope 0 at $DIR/issue_41110.rs:+1:21: +1:27
                                           // mir::Constant
                                           // + span: $DIR/issue_41110.rs:8:23: 8:25
                                           // + literal: Const { ty: fn(S) -> S {S::id}, val: Value(<ZST>) }
      }
  
      bb1: {
          StorageDead(_4);                 // scope 0 at $DIR/issue_41110.rs:+1:26: +1:27
+         _5 = const false;                // scope 0 at $DIR/issue_41110.rs:+1:13: +1:28
          _1 = S::other(move _2, move _3) -> [return: bb2, unwind: bb3]; // scope 0 at $DIR/issue_41110.rs:+1:13: +1:28
                                           // mir::Constant
                                           // + span: $DIR/issue_41110.rs:8:15: 8:20
                                           // + literal: Const { ty: fn(S, S) {S::other}, val: Value(<ZST>) }
      }
  
      bb2: {
          StorageDead(_3);                 // scope 0 at $DIR/issue_41110.rs:+1:27: +1:28
+         _5 = const false;                // scope 0 at $DIR/issue_41110.rs:+1:27: +1:28
          StorageDead(_2);                 // scope 0 at $DIR/issue_41110.rs:+1:27: +1:28
          _0 = const ();                   // scope 0 at $DIR/issue_41110.rs:+0:11: +2:2
          StorageDead(_1);                 // scope 0 at $DIR/issue_41110.rs:+2:1: +2:2
          return;                          // scope 0 at $DIR/issue_41110.rs:+2:2: +2:2
      }
  
      bb3 (cleanup): {
-         drop(_3) -> bb5;                 // scope 0 at $DIR/issue_41110.rs:+1:27: +1:28
+         goto -> bb5;                     // scope 0 at $DIR/issue_41110.rs:+1:27: +1:28
      }
  
      bb4 (cleanup): {
-         drop(_4) -> bb5;                 // scope 0 at $DIR/issue_41110.rs:+1:26: +1:27
+         goto -> bb5;                     // scope 0 at $DIR/issue_41110.rs:+1:26: +1:27
      }
  
      bb5 (cleanup): {
-         drop(_2) -> bb6;                 // scope 0 at $DIR/issue_41110.rs:+1:27: +1:28
+         goto -> bb8;                     // scope 0 at $DIR/issue_41110.rs:+1:27: +1:28
      }
  
      bb6 (cleanup): {
          resume;                          // scope 0 at $DIR/issue_41110.rs:+0:1: +2:2
+     }
+ 
+     bb7 (cleanup): {
+         drop(_2) -> bb6;                 // scope 0 at $DIR/issue_41110.rs:+1:27: +1:28
+     }
+ 
+     bb8 (cleanup): {
+         switchInt(_5) -> [0: bb6, otherwise: bb7]; // scope 0 at $DIR/issue_41110.rs:+1:27: +1:28
      }
  }