summaryrefslogtreecommitdiffstats
path: root/src/test/ui/pattern/issue-67776-match-same-name-enum-variant-refs.rs
blob: 6fd5768a5a26dd2e032ed6726fc13160155ef256 (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
// Test for issue #67776: binding named the same as enum variant
// should report a warning even when matching against a reference type

// check-pass

#![allow(unused_variables)]
#![allow(non_snake_case)]

enum Foo {
    Bar,
    Baz,
}


fn fn1(e: Foo) {
    match e {
        Bar => {},
        //~^ WARNING named the same as one of the variants of the type `Foo`
        Baz => {},
        //~^ WARNING named the same as one of the variants of the type `Foo`
    }
}

fn fn2(e: &Foo) {
    match e {
        Bar => {},
        //~^ WARNING named the same as one of the variants of the type `Foo`
        Baz => {},
        //~^ WARNING named the same as one of the variants of the type `Foo`
    }
}

fn fn3(e: &mut &&mut Foo) {
    match e {
        Bar => {},
        //~^ WARNING named the same as one of the variants of the type `Foo`
        Baz => {},
        //~^ WARNING named the same as one of the variants of the type `Foo`
    }
}

fn main() {}