// This test tests the precedence of `|` (or-patterns) undelimited nested patterns. In particular, // we want to reserve the syntactic space of a pattern followed by a type annotation for possible // future type ascription, so we need to make sure that any time a pattern is followed by type // annotation (for now), the pattern is not a top-level or-pattern. However, there are also a few // types of patterns that allow undelimited subpatterns that could cause the same ambiguity. // Currently, those should be impossible due to precedence rule. This test enforces that. enum E { A, B, } fn foo() { use E::*; // ok let b @ (A | B): E = A; let b @ A | B: E = A; //~ERROR `b` is not bound in all patterns //~^ ERROR top-level or-patterns are not allowed } enum F { A(usize), B(usize), } fn bar() { use F::*; // ok let (A(x) | B(x)): F = A(3); let &A(_) | B(_): F = A(3); //~ERROR mismatched types //~^ ERROR top-level or-patterns are not allowed let &&A(_) | B(_): F = A(3); //~ERROR mismatched types //~^ ERROR top-level or-patterns are not allowed let &mut A(_) | B(_): F = A(3); //~ERROR mismatched types //~^ ERROR top-level or-patterns are not allowed let &&mut A(_) | B(_): F = A(3); //~ERROR mismatched types //~^ ERROR top-level or-patterns are not allowed } fn main() {}