rust/tests/ui/or-patterns/or-patterns-syntactic-fail.rs

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

34 lines
1.1 KiB
Rust
Raw Normal View History

2019-08-18 21:53:08 +00:00
// Test some cases where or-patterns may ostensibly be allowed but are in fact not.
// This is not a semantic test. We only test parsing.
fn main() {}
enum E { A, B }
use E::*;
fn no_top_level_or_patterns() {
// We do *not* allow or-patterns at the top level of lambdas...
let _ = |A | B: E| ();
//~^ ERROR expected identifier, found
2019-08-18 21:53:08 +00:00
// -------- This looks like an or-pattern but is in fact `|A| (B: E | ())`.
}
2019-08-18 21:53:08 +00:00
fn no_top_level_or_patterns_2() {
2019-08-18 21:53:08 +00:00
// ...and for now neither do we allow or-patterns at the top level of functions.
fn fun1(A | B: E) {}
//~^ ERROR top-level or-patterns are not allowed
fn fun2(| A | B: E) {}
//~^ ERROR top-level or-patterns are not allowed
// We don't allow top-level or-patterns before type annotation in let-statements because we
// want to reserve this syntactic space for possible future type ascription.
let A | B: E = A;
//~^ ERROR top-level or-patterns are not allowed
let | A | B: E = A;
//~^ ERROR top-level or-patterns are not allowed
let (A | B): E = A; // ok -- wrapped in parens
2019-08-18 21:53:08 +00:00
}