1 // compile-flags: -Z span_free_formats
3 // Tests that MIR inliner can handle closure captures.
6 println!("{:?}", foo(0, 14));
9 fn foo<T: Copy>(t: T, q: i32) -> (i32, T) {
15 // START rustc.foo.Inline.after.mir
16 // fn foo(_1: T, _2: i32) -> (i32, T){
19 // let mut _0: (i32, T);
20 // let _3: [closure@HirId { owner: DefIndex(4), local_id: 15 } q:&i32, t:&T];
23 // let mut _6: &[closure@HirId { owner: DefIndex(4), local_id: 15 } q:&i32, t:&T];
24 // let mut _7: (i32,);
31 // debug q => (*((*_6).0: &i32));
32 // debug t => (*((*_6).1: &T));
42 // _3 = [closure@HirId { owner: DefIndex(4), local_id: 15 }] { q: move _4, t: move _5 };
49 // _11 = move (_7.0: i32);
51 // _9 = (*((*_6).0: &i32));
53 // _10 = (*((*_6).1: &T));
54 // (_0.0: i32) = move _9;
55 // (_0.1: T) = move _10;
60 // END rustc.foo.Inline.after.mir