blob: 8eae04c4dd4a696386f53dddc2c4a2266594f758 (
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 `get_query` before Inline
+ // MIR for `get_query` after Inline
fn get_query(_1: &T) -> () {
debug t => _1; // in scope 0 at $DIR/dyn-trait.rs:+0:31: +0:32
let mut _0: (); // return place in scope 0 at $DIR/dyn-trait.rs:+0:38: +0:38
let _2: &<Q as Query>::C; // in scope 0 at $DIR/dyn-trait.rs:+1:9: +1:10
let mut _3: &T; // in scope 0 at $DIR/dyn-trait.rs:+1:22: +1:23
let mut _4: &<Q as Query>::C; // in scope 0 at $DIR/dyn-trait.rs:+2:23: +2:24
scope 1 {
debug c => _2; // in scope 1 at $DIR/dyn-trait.rs:+1:9: +1:10
+ scope 2 (inlined try_execute_query::<<Q as Query>::C>) { // at $DIR/dyn-trait.rs:34:5: 34:25
+ debug c => _4; // in scope 2 at $DIR/dyn-trait.rs:+0:36: +0:37
+ let mut _5: &dyn Cache<V = <Q as Query>::V>; // in scope 2 at $DIR/dyn-trait.rs:+0:14: +0:15
+ let mut _6: &<Q as Query>::C; // in scope 2 at $DIR/dyn-trait.rs:+0:14: +0:15
+ scope 3 (inlined mk_cycle::<<Q as Query>::V>) { // at $DIR/dyn-trait.rs:27:5: 27:16
+ debug c => _5; // in scope 3 at $DIR/dyn-trait.rs:+0:27: +0:28
+ let mut _7: &dyn Cache<V = <Q as Query>::V>; // in scope 3 at $DIR/dyn-trait.rs:+0:5: +0:22
+ }
+ }
}
bb0: {
StorageLive(_2); // scope 0 at $DIR/dyn-trait.rs:+1:9: +1:10
StorageLive(_3); // scope 0 at $DIR/dyn-trait.rs:+1:22: +1:23
_3 = &(*_1); // scope 0 at $DIR/dyn-trait.rs:+1:22: +1:23
_2 = <Q as Query>::cache::<T>(move _3) -> bb1; // scope 0 at $DIR/dyn-trait.rs:+1:13: +1:24
// mir::Constant
// + span: $DIR/dyn-trait.rs:33:13: 33:21
// + user_ty: UserType(0)
// + literal: Const { ty: for<'r> fn(&'r T) -> &'r <Q as Query>::C {<Q as Query>::cache::<T>}, val: Value(<ZST>) }
}
bb1: {
StorageDead(_3); // scope 0 at $DIR/dyn-trait.rs:+1:23: +1:24
StorageLive(_4); // scope 1 at $DIR/dyn-trait.rs:+2:23: +2:24
_4 = &(*_2); // scope 1 at $DIR/dyn-trait.rs:+2:23: +2:24
- _0 = try_execute_query::<<Q as Query>::C>(move _4) -> bb2; // scope 1 at $DIR/dyn-trait.rs:+2:5: +2:25
+ StorageLive(_5); // scope 2 at $DIR/dyn-trait.rs:+0:14: +0:15
+ StorageLive(_6); // scope 2 at $DIR/dyn-trait.rs:+0:14: +0:15
+ _6 = _4; // scope 2 at $DIR/dyn-trait.rs:+0:14: +0:15
+ _5 = move _6 as &dyn Cache<V = <Q as Query>::V> (Pointer(Unsize)); // scope 2 at $DIR/dyn-trait.rs:+0:14: +0:15
+ StorageDead(_6); // scope 2 at $DIR/dyn-trait.rs:+0:14: +0:15
+ StorageLive(_7); // scope 3 at $DIR/dyn-trait.rs:+0:5: +0:22
+ _7 = _5; // scope 3 at $DIR/dyn-trait.rs:+0:5: +0:22
+ _0 = <dyn Cache<V = <Q as Query>::V> as Cache>::store_nocache(move _7) -> bb2; // scope 3 at $DIR/dyn-trait.rs:+0:5: +0:22
// mir::Constant
- // + span: $DIR/dyn-trait.rs:34:5: 34:22
- // + literal: Const { ty: for<'r> fn(&'r <Q as Query>::C) {try_execute_query::<<Q as Query>::C>}, val: Value(<ZST>) }
+ // + span: $DIR/dyn-trait.rs:21:7: 21:20
+ // + literal: Const { ty: for<'r> fn(&'r dyn Cache<V = <Q as Query>::V>) {<dyn Cache<V = <Q as Query>::V> as Cache>::store_nocache}, val: Value(<ZST>) }
}
bb2: {
+ StorageDead(_7); // scope 3 at $DIR/dyn-trait.rs:+0:21: +0:22
+ StorageDead(_5); // scope 2 at $DIR/dyn-trait.rs:+0:15: +0:16
StorageDead(_4); // scope 1 at $DIR/dyn-trait.rs:+2:24: +2:25
StorageDead(_2); // scope 0 at $DIR/dyn-trait.rs:+3:1: +3:2
return; // scope 0 at $DIR/dyn-trait.rs:+3:2: +3:2
}
}
|