5804a30686
...of the type being matched. This change will result in a better diagnostic for code like the following: ```rust enum Enum { Foo, Bar } fn f(x: Enum) { match x { Foo => (), Bar => () } } ``` which would currently simply fail with an unreachable pattern error on the 2nd arm. The user is advised to either use a qualified path in the patterns or import the variants explicitly into the scope.
35 lines
1.0 KiB
Rust
35 lines
1.0 KiB
Rust
// Copyright 2014 The Rust Project Developers. See the COPYRIGHT
|
|
// file at the top-level directory of this distribution and at
|
|
// http://rust-lang.org/COPYRIGHT.
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
|
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
|
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
|
// option. This file may not be copied, modified, or distributed
|
|
// except according to those terms.
|
|
|
|
enum Foo {
|
|
Bar,
|
|
Baz
|
|
}
|
|
|
|
impl Foo {
|
|
fn foo(&self) {
|
|
match self {
|
|
&
|
|
Bar if true
|
|
//~^ WARN pattern binding `Bar` is named the same as one of the variants of the type `Foo`
|
|
//~^^ HELP to match on a variant, consider making the path in the pattern qualified: `Foo::Bar`
|
|
=> println!("bar"),
|
|
&
|
|
Baz if false
|
|
//~^ WARN pattern binding `Baz` is named the same as one of the variants of the type `Foo`
|
|
//~^^ HELP to match on a variant, consider making the path in the pattern qualified: `Foo::Baz`
|
|
=> println!("baz"),
|
|
_ => ()
|
|
}
|
|
}
|
|
}
|
|
|
|
fn main() {}
|