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
|
//@ check-pass
// Test that `ref` patterns may be used on both sides
// of an `@` pattern according to NLL borrowck.
fn main() {
struct U; // Not copy!
// Promotion:
let ref a @ ref b = U;
let _: &U = a;
let _: &U = b;
// Prevent promotion:
fn u() -> U { U }
let ref a @ ref b = u();
let _: &U = a;
let _: &U = b;
let ref a @ (ref b, [ref c, ref d]) = (u(), [u(), u()]);
let _: &(U, [U; 2]) = a;
let _: &U = b;
let _: &U = c;
let _: &U = d;
fn f1(ref a @ (ref b, [ref c, ref mid @ .., ref d]): (U, [U; 4])) {}
let a @ (b, [c, d]) = &(u(), [u(), u()]);
let _: &(U, [U; 2]) = a;
let _: &U = b;
let _: &U = c;
let _: &U = d;
let ref a @ &ref b = &u();
let _: &&U = a;
let _: &U = b;
match Ok(u()) {
ref a @ Ok(ref b) | ref a @ Err(ref b) => {
let _: &Result<U, U> = a;
let _: &U = b;
}
}
}
|