summaryrefslogtreecommitdiffstats
path: root/tests/ui/or-patterns/or-patterns-syntactic-pass.rs
blob: 92750bec8b20c9bfaf771beeefdc96d140bced38 (plain)
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
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
// Here we test all the places `|` is *syntactically* allowed.
// This is not a semantic test. We only test parsing.

// check-pass

fn main() {}

// Test the `pat` macro fragment parser:
macro_rules! accept_pat {
    ($p:pat) => {};
}

accept_pat!((p | q));
accept_pat!((p | q,));
accept_pat!(TS(p | q));
accept_pat!(NS { f: p | q });
accept_pat!([p | q]);

// Non-macro tests:

#[cfg(FALSE)]
fn or_patterns() {
    // Top level of `let`:
    let (| A | B);
    let (A | B);
    let (A | B): u8;
    let (A | B) = 0;
    let (A | B): u8 = 0;

    // Top level of `for`:
    for | A | B in 0 {}
    for A | B in 0 {}

    // Top level of `while`:
    while let | A | B = 0 {}
    while let A | B = 0 {}

    // Top level of `if`:
    if let | A | B = 0 {}
    if let A | B = 0 {}

    // Top level of `match` arms:
    match 0 {
        | A | B => {}
        A | B => {}
    }

    // Functions:
    fn fun((A | B): _) {}

    // Lambdas:
    let _ = |(A | B): u8| ();

    // Parenthesis and tuple patterns:
    let (A | B);
    let (A | B,);

    // Tuple struct patterns:
    let A(B | C);
    let E::V(B | C);

    // Struct patterns:
    let S { f1: B | C, f2 };
    let E::V { f1: B | C, f2 };

    // Slice patterns:
    let [A | B, .. | ..];

    // These bind as `(prefix p) | q` as opposed to `prefix (p | q)`:
    let (box 0 | 1); // Unstable; we *can* change the precedence if we want.
                     //~^ WARN box pattern syntax is experimental
                     //~| WARN unstable syntax
    let (&0 | 1);
    let (&mut 0 | 1);
    let (x @ 0 | 1);
    let (ref x @ 0 | 1);
    let (ref mut x @ 0 | 1);
}