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];
}
}
|