2019-08-18 16:53:08 -05: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...
|
2022-11-16 14:46:06 -06:00
|
|
|
let _ = |A | B: E| ();
|
|
|
|
//~^ ERROR expected identifier, found
|
2019-08-18 16:53:08 -05:00
|
|
|
// -------- This looks like an or-pattern but is in fact `|A| (B: E | ())`.
|
2022-11-16 14:46:06 -06:00
|
|
|
}
|
2019-08-18 16:53:08 -05:00
|
|
|
|
2022-11-16 14:46:06 -06:00
|
|
|
fn no_top_level_or_patterns_2() {
|
2019-08-18 16:53:08 -05:00
|
|
|
// ...and for now neither do we allow or-patterns at the top level of functions.
|
2021-02-12 18:04:37 -06:00
|
|
|
fn fun1(A | B: E) {}
|
|
|
|
//~^ ERROR top-level or-patterns are not allowed
|
2019-08-24 21:39:28 -05:00
|
|
|
|
|
|
|
fn fun2(| A | B: E) {}
|
2021-02-12 18:04:37 -06:00
|
|
|
//~^ 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 16:53:08 -05:00
|
|
|
}
|