// 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 = a; let _: &U = b; } } }