2020-07-14 14:59:59 +02:00
|
|
|
// run-rustfix
|
|
|
|
|
|
|
|
#![warn(clippy::match_like_matches_macro)]
|
2021-10-04 10:03:40 +03:30
|
|
|
#![allow(unreachable_patterns, dead_code, clippy::equatable_if_let)]
|
2020-07-14 14:59:59 +02:00
|
|
|
|
|
|
|
fn main() {
|
|
|
|
let x = Some(5);
|
|
|
|
|
|
|
|
// Lint
|
|
|
|
let _y = matches!(x, Some(0));
|
|
|
|
|
|
|
|
// Lint
|
|
|
|
let _w = matches!(x, Some(_));
|
|
|
|
|
|
|
|
// Turn into is_none
|
|
|
|
let _z = x.is_none();
|
|
|
|
|
|
|
|
// Lint
|
|
|
|
let _zz = !matches!(x, Some(r) if r == 0);
|
|
|
|
|
|
|
|
// Lint
|
|
|
|
let _zzz = matches!(x, Some(5));
|
|
|
|
|
|
|
|
// No lint
|
|
|
|
let _a = match x {
|
|
|
|
Some(_) => false,
|
|
|
|
_ => false,
|
|
|
|
};
|
|
|
|
|
|
|
|
// No lint
|
|
|
|
let _ab = match x {
|
|
|
|
Some(0) => false,
|
|
|
|
_ => true,
|
|
|
|
None => false,
|
|
|
|
};
|
2020-10-28 23:36:07 +01:00
|
|
|
|
|
|
|
enum E {
|
|
|
|
A(u32),
|
|
|
|
B(i32),
|
|
|
|
C,
|
|
|
|
D,
|
2020-12-29 17:15:53 -05:00
|
|
|
}
|
2020-10-28 23:36:07 +01:00
|
|
|
let x = E::A(2);
|
|
|
|
{
|
|
|
|
// lint
|
|
|
|
let _ans = matches!(x, E::A(_) | E::B(_));
|
|
|
|
}
|
|
|
|
{
|
|
|
|
// lint
|
|
|
|
let _ans = !matches!(x, E::B(_) | E::C);
|
|
|
|
}
|
|
|
|
{
|
|
|
|
// no lint
|
|
|
|
let _ans = match x {
|
|
|
|
E::A(_) => false,
|
|
|
|
E::B(_) => false,
|
|
|
|
E::C => true,
|
|
|
|
_ => true,
|
|
|
|
};
|
|
|
|
}
|
|
|
|
{
|
|
|
|
// no lint
|
|
|
|
let _ans = match x {
|
|
|
|
E::A(_) => true,
|
|
|
|
E::B(_) => false,
|
|
|
|
E::C => false,
|
|
|
|
_ => true,
|
|
|
|
};
|
|
|
|
}
|
|
|
|
{
|
|
|
|
// no lint
|
|
|
|
let _ans = match x {
|
|
|
|
E::A(a) if a < 10 => false,
|
|
|
|
E::B(a) if a < 10 => false,
|
|
|
|
_ => true,
|
|
|
|
};
|
|
|
|
}
|
|
|
|
{
|
|
|
|
// no lint
|
|
|
|
let _ans = match x {
|
|
|
|
E::A(_) => false,
|
|
|
|
E::B(a) if a < 10 => false,
|
|
|
|
_ => true,
|
|
|
|
};
|
|
|
|
}
|
|
|
|
{
|
|
|
|
// no lint
|
|
|
|
let _ans = match x {
|
|
|
|
E::A(a) => a == 10,
|
|
|
|
E::B(_) => false,
|
|
|
|
_ => true,
|
|
|
|
};
|
|
|
|
}
|
|
|
|
{
|
|
|
|
// no lint
|
|
|
|
let _ans = match x {
|
|
|
|
E::A(_) => false,
|
|
|
|
E::B(_) => true,
|
|
|
|
_ => false,
|
|
|
|
};
|
|
|
|
}
|
2021-01-01 17:43:24 +01:00
|
|
|
|
|
|
|
{
|
|
|
|
// should print "z" in suggestion (#6503)
|
|
|
|
let z = &Some(3);
|
|
|
|
let _z = matches!(z, Some(3));
|
|
|
|
}
|
|
|
|
|
|
|
|
{
|
|
|
|
// this could also print "z" in suggestion..?
|
|
|
|
let z = Some(3);
|
|
|
|
let _z = matches!(&z, Some(3));
|
|
|
|
}
|
|
|
|
|
|
|
|
{
|
|
|
|
enum AnEnum {
|
|
|
|
X,
|
|
|
|
Y,
|
|
|
|
}
|
|
|
|
|
|
|
|
fn foo(_x: AnEnum) {}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
let z = AnEnum::X;
|
|
|
|
// we can't remove the reference here!
|
|
|
|
let _ = matches!(&z, AnEnum::X);
|
|
|
|
foo(z);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
{
|
|
|
|
struct S(i32);
|
|
|
|
|
|
|
|
fn fun(_val: Option<S>) {}
|
|
|
|
let val = Some(S(42));
|
|
|
|
// we need the reference here because later val is consumed by fun()
|
|
|
|
let _res = matches!(&val, &Some(ref _a));
|
|
|
|
fun(val);
|
|
|
|
}
|
|
|
|
|
|
|
|
{
|
|
|
|
struct S(i32);
|
|
|
|
|
|
|
|
fn fun(_val: Option<S>) {}
|
|
|
|
let val = Some(S(42));
|
|
|
|
let _res = matches!(&val, &Some(ref _a));
|
|
|
|
fun(val);
|
|
|
|
}
|
2020-07-14 14:59:59 +02:00
|
|
|
}
|