d69725d5d5
Since this only affects `PreCodegen MIR, and it would be nice for that to be resilient to permutations of things that don't affect the actual semantic behaviours.
69 lines
5.6 KiB
Rust
69 lines
5.6 KiB
Rust
// MIR for `foo` after Inline
|
|
|
|
fn foo(_1: T, _2: i32) -> (i32, T) {
|
|
debug t => _1; // in scope 0 at $DIR/inline_closure_captures.rs:+0:17: +0:18
|
|
debug q => _2; // in scope 0 at $DIR/inline_closure_captures.rs:+0:23: +0:24
|
|
let mut _0: (i32, T); // return place in scope 0 at $DIR/inline_closure_captures.rs:+0:34: +0:42
|
|
let _3: [closure@foo<T>::{closure#0}]; // in scope 0 at $DIR/inline_closure_captures.rs:+1:9: +1:10
|
|
let mut _4: &i32; // in scope 0 at $DIR/inline_closure_captures.rs:+1:13: +1:24
|
|
let mut _5: &T; // in scope 0 at $DIR/inline_closure_captures.rs:+1:13: +1:24
|
|
let mut _6: &[closure@foo<T>::{closure#0}]; // in scope 0 at $DIR/inline_closure_captures.rs:+2:5: +2:6
|
|
let mut _7: (i32,); // in scope 0 at $DIR/inline_closure_captures.rs:+2:5: +2:9
|
|
let mut _8: i32; // in scope 0 at $DIR/inline_closure_captures.rs:+2:7: +2:8
|
|
let mut _9: i32; // in scope 0 at $DIR/inline_closure_captures.rs:+2:5: +2:9
|
|
scope 1 {
|
|
debug x => _3; // in scope 1 at $DIR/inline_closure_captures.rs:+1:9: +1:10
|
|
scope 2 (inlined foo::<T>::{closure#0}) { // at $DIR/inline_closure_captures.rs:12:5: 12:9
|
|
debug _q => _9; // in scope 2 at $DIR/inline_closure_captures.rs:+1:14: +1:16
|
|
debug q => (*((*_6).0: &i32)); // in scope 2 at $DIR/inline_closure_captures.rs:+0:23: +0:24
|
|
debug t => (*((*_6).1: &T)); // in scope 2 at $DIR/inline_closure_captures.rs:+0:17: +0:18
|
|
let mut _10: &i32; // in scope 2 at $DIR/inline_closure_captures.rs:+1:13: +1:24
|
|
let mut _11: i32; // in scope 2 at $DIR/inline_closure_captures.rs:+1:19: +1:20
|
|
let mut _12: &T; // in scope 2 at $DIR/inline_closure_captures.rs:+1:13: +1:24
|
|
let mut _13: T; // in scope 2 at $DIR/inline_closure_captures.rs:+1:22: +1:23
|
|
}
|
|
}
|
|
|
|
bb0: {
|
|
StorageLive(_3); // scope 0 at $DIR/inline_closure_captures.rs:+1:9: +1:10
|
|
StorageLive(_4); // scope 0 at $DIR/inline_closure_captures.rs:+1:13: +1:24
|
|
_4 = &_2; // scope 0 at $DIR/inline_closure_captures.rs:+1:13: +1:24
|
|
StorageLive(_5); // scope 0 at $DIR/inline_closure_captures.rs:+1:13: +1:24
|
|
_5 = &_1; // scope 0 at $DIR/inline_closure_captures.rs:+1:13: +1:24
|
|
_3 = [closure@foo::<T>::{closure#0}] { q: move _4, t: move _5 }; // scope 0 at $DIR/inline_closure_captures.rs:+1:13: +1:24
|
|
// closure
|
|
// + def_id: DefId(0:6 ~ inline_closure_captures[63a5]::foo::{closure#0})
|
|
// + substs: [
|
|
// T,
|
|
// i8,
|
|
// extern "rust-call" fn((i32,)) -> (i32, T),
|
|
// (&i32, &T),
|
|
// ]
|
|
StorageDead(_5); // scope 0 at $DIR/inline_closure_captures.rs:+1:16: +1:17
|
|
StorageDead(_4); // scope 0 at $DIR/inline_closure_captures.rs:+1:16: +1:17
|
|
StorageLive(_6); // scope 1 at $DIR/inline_closure_captures.rs:+2:5: +2:6
|
|
_6 = &_3; // scope 1 at $DIR/inline_closure_captures.rs:+2:5: +2:6
|
|
StorageLive(_7); // scope 1 at $DIR/inline_closure_captures.rs:+2:5: +2:9
|
|
StorageLive(_8); // scope 1 at $DIR/inline_closure_captures.rs:+2:7: +2:8
|
|
_8 = _2; // scope 1 at $DIR/inline_closure_captures.rs:+2:7: +2:8
|
|
_7 = (move _8,); // scope 1 at $DIR/inline_closure_captures.rs:+2:5: +2:9
|
|
StorageLive(_9); // scope 1 at $DIR/inline_closure_captures.rs:+2:5: +2:9
|
|
_9 = move (_7.0: i32); // scope 1 at $DIR/inline_closure_captures.rs:+2:5: +2:9
|
|
StorageLive(_11); // scope 2 at $DIR/inline_closure_captures.rs:+1:19: +1:20
|
|
_10 = deref_copy ((*_6).0: &i32); // scope 2 at $DIR/inline_closure_captures.rs:+1:19: +1:20
|
|
_11 = (*_10); // scope 2 at $DIR/inline_closure_captures.rs:+1:19: +1:20
|
|
StorageLive(_13); // scope 2 at $DIR/inline_closure_captures.rs:+1:22: +1:23
|
|
_12 = deref_copy ((*_6).1: &T); // scope 2 at $DIR/inline_closure_captures.rs:+1:22: +1:23
|
|
_13 = (*_12); // scope 2 at $DIR/inline_closure_captures.rs:+1:22: +1:23
|
|
_0 = (move _11, move _13); // scope 2 at $DIR/inline_closure_captures.rs:+1:18: +1:24
|
|
StorageDead(_13); // scope 2 at $DIR/inline_closure_captures.rs:+1:23: +1:24
|
|
StorageDead(_11); // scope 2 at $DIR/inline_closure_captures.rs:+1:23: +1:24
|
|
StorageDead(_9); // scope 1 at $DIR/inline_closure_captures.rs:+2:5: +2:9
|
|
StorageDead(_8); // scope 1 at $DIR/inline_closure_captures.rs:+2:8: +2:9
|
|
StorageDead(_7); // scope 1 at $DIR/inline_closure_captures.rs:+2:8: +2:9
|
|
StorageDead(_6); // scope 1 at $DIR/inline_closure_captures.rs:+2:8: +2:9
|
|
StorageDead(_3); // scope 0 at $DIR/inline_closure_captures.rs:+3:1: +3:2
|
|
return; // scope 0 at $DIR/inline_closure_captures.rs:+3:2: +3:2
|
|
}
|
|
}
|