2020-05-28 13:45:24 +00:00
|
|
|
#![warn(clippy::match_wildcard_for_single_variants)]
|
|
|
|
#![allow(dead_code)]
|
|
|
|
|
|
|
|
enum Foo {
|
|
|
|
A,
|
|
|
|
B,
|
|
|
|
C,
|
|
|
|
}
|
|
|
|
|
|
|
|
enum Color {
|
|
|
|
Red,
|
|
|
|
Green,
|
|
|
|
Blue,
|
|
|
|
Rgb(u8, u8, u8),
|
|
|
|
}
|
2021-03-25 18:29:11 +00:00
|
|
|
impl Color {
|
|
|
|
fn f(self) {
|
|
|
|
match self {
|
|
|
|
Self::Red => (),
|
|
|
|
Self::Green => (),
|
|
|
|
Self::Blue => (),
|
|
|
|
Self::Rgb(..) => (),
|
|
|
|
};
|
|
|
|
}
|
|
|
|
}
|
2020-05-28 13:45:24 +00:00
|
|
|
|
|
|
|
fn main() {
|
|
|
|
let f = Foo::A;
|
|
|
|
match f {
|
|
|
|
Foo::A => {},
|
|
|
|
Foo::B => {},
|
|
|
|
Foo::C => {},
|
|
|
|
}
|
|
|
|
|
|
|
|
let color = Color::Red;
|
|
|
|
|
|
|
|
// check exhaustive bindings
|
|
|
|
match color {
|
|
|
|
Color::Red => {},
|
|
|
|
Color::Green => {},
|
|
|
|
Color::Rgb(_r, _g, _b) => {},
|
|
|
|
Color::Blue => {},
|
|
|
|
}
|
|
|
|
|
|
|
|
// check exhaustive wild
|
|
|
|
match color {
|
|
|
|
Color::Red => {},
|
|
|
|
Color::Green => {},
|
|
|
|
Color::Rgb(..) => {},
|
|
|
|
Color::Blue => {},
|
|
|
|
}
|
|
|
|
match color {
|
|
|
|
Color::Red => {},
|
|
|
|
Color::Green => {},
|
|
|
|
Color::Rgb(_, _, _) => {},
|
|
|
|
Color::Blue => {},
|
|
|
|
}
|
|
|
|
|
|
|
|
// shouldn't lint as there is one missing variant
|
|
|
|
// and one that isn't exhaustively covered
|
|
|
|
match color {
|
|
|
|
Color::Red => {},
|
|
|
|
Color::Green => {},
|
|
|
|
Color::Rgb(255, _, _) => {},
|
|
|
|
_ => {},
|
|
|
|
}
|
2021-03-25 18:29:11 +00:00
|
|
|
|
|
|
|
// References shouldn't change anything
|
|
|
|
match &color {
|
|
|
|
&Color::Red => (),
|
|
|
|
Color::Green => (),
|
|
|
|
&Color::Rgb(..) => (),
|
|
|
|
Color::Blue => (),
|
|
|
|
}
|
|
|
|
|
|
|
|
use self::Color as C;
|
|
|
|
|
|
|
|
match color {
|
|
|
|
C::Red => (),
|
|
|
|
C::Green => (),
|
|
|
|
C::Rgb(..) => (),
|
|
|
|
C::Blue => (),
|
|
|
|
}
|
|
|
|
|
|
|
|
match color {
|
|
|
|
C::Red => (),
|
|
|
|
Color::Green => (),
|
|
|
|
Color::Rgb(..) => (),
|
|
|
|
Color::Blue => (),
|
|
|
|
}
|
|
|
|
|
|
|
|
match Some(0) {
|
|
|
|
Some(0) => 0,
|
|
|
|
Some(_) => 1,
|
|
|
|
_ => 2,
|
|
|
|
};
|
|
|
|
|
|
|
|
#[non_exhaustive]
|
|
|
|
enum Bar {
|
|
|
|
A,
|
|
|
|
B,
|
|
|
|
C,
|
|
|
|
}
|
|
|
|
match Bar::A {
|
|
|
|
Bar::A => (),
|
|
|
|
Bar::B => (),
|
|
|
|
_ => (),
|
|
|
|
};
|
2021-04-08 15:50:13 +00:00
|
|
|
|
|
|
|
//#6984
|
|
|
|
{
|
|
|
|
#![allow(clippy::manual_non_exhaustive)]
|
|
|
|
pub enum Enum {
|
|
|
|
A,
|
|
|
|
B,
|
2021-07-01 16:17:38 +00:00
|
|
|
C,
|
2021-04-08 15:50:13 +00:00
|
|
|
#[doc(hidden)]
|
|
|
|
__Private,
|
|
|
|
}
|
2021-07-01 16:17:38 +00:00
|
|
|
match Enum::A {
|
|
|
|
Enum::A => (),
|
|
|
|
Enum::B => (),
|
|
|
|
Enum::C => (),
|
2023-02-10 13:01:19 +00:00
|
|
|
Enum::__Private => (),
|
2021-07-01 16:17:38 +00:00
|
|
|
}
|
2021-04-08 15:50:13 +00:00
|
|
|
match Enum::A {
|
|
|
|
Enum::A => (),
|
|
|
|
Enum::B => (),
|
|
|
|
_ => (),
|
|
|
|
}
|
|
|
|
}
|
2020-05-28 13:45:24 +00:00
|
|
|
}
|
2022-12-29 13:28:34 +00:00
|
|
|
|
|
|
|
mod issue9993 {
|
|
|
|
enum Foo {
|
|
|
|
A(bool),
|
|
|
|
B,
|
|
|
|
}
|
|
|
|
|
|
|
|
fn test() {
|
|
|
|
let _ = match Foo::A(true) {
|
|
|
|
_ if false => 0,
|
|
|
|
Foo::A(true) => 1,
|
|
|
|
Foo::A(false) => 2,
|
|
|
|
Foo::B => 3,
|
|
|
|
};
|
|
|
|
|
|
|
|
let _ = match Foo::B {
|
|
|
|
_ if false => 0,
|
|
|
|
Foo::A(_) => 1,
|
|
|
|
Foo::B => 2,
|
|
|
|
};
|
|
|
|
}
|
|
|
|
}
|