summaryrefslogtreecommitdiffstats
path: root/tests/mir-opt/inline/issue_78442.bar.Inline.panic-unwind.diff
blob: c67babba23e80f7179224122a374d8fa8d865269 (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
- // MIR for `bar` before Inline
+ // MIR for `bar` after Inline
  
  fn bar(_1: P) -> () {
      debug _baz => _1;
      let mut _0: ();
      let _2: ();
      let mut _3: &fn() {foo};
      let _4: fn() {foo};
      let mut _5: ();
+     scope 1 (inlined <fn() {foo} as Fn<()>>::call - shim(fn() {foo})) {
+     }
  
      bb0: {
          StorageLive(_2);
          StorageLive(_3);
          StorageLive(_4);
-         _4 = hide_foo() -> [return: bb1, unwind: bb4];
+         _4 = hide_foo() -> [return: bb1, unwind: bb3];
      }
  
      bb1: {
          _3 = &_4;
          StorageLive(_5);
          _5 = ();
-         _2 = <fn() {foo} as Fn<()>>::call(move _3, move _5) -> [return: bb2, unwind: bb4];
+         _2 = move (*_3)() -> [return: bb5, unwind: bb3];
      }
  
      bb2: {
-         StorageDead(_5);
-         StorageDead(_3);
-         StorageDead(_4);
-         StorageDead(_2);
-         _0 = const ();
-         drop(_1) -> [return: bb3, unwind: bb5];
+         return;
      }
  
-     bb3: {
-         return;
+     bb3 (cleanup): {
+         drop(_1) -> [return: bb4, unwind terminate];
      }
  
      bb4 (cleanup): {
-         drop(_1) -> [return: bb5, unwind terminate];
+         resume;
      }
  
-     bb5 (cleanup): {
-         resume;
+     bb5: {
+         StorageDead(_5);
+         StorageDead(_3);
+         StorageDead(_4);
+         StorageDead(_2);
+         _0 = const ();
+         drop(_1) -> [return: bb2, unwind: bb4];
      }
  }