2019-09-21 00:26:18 -05:00
|
|
|
// run-rustfix
|
|
|
|
|
|
|
|
#![deny(clippy::wildcard_enum_match_arm)]
|
2019-12-26 22:42:28 -06:00
|
|
|
#![allow(
|
|
|
|
unreachable_code,
|
|
|
|
unused_variables,
|
|
|
|
dead_code,
|
|
|
|
clippy::single_match,
|
2020-06-09 09:36:01 -05:00
|
|
|
clippy::wildcard_in_or_patterns,
|
2020-12-06 08:01:03 -06:00
|
|
|
clippy::unnested_or_patterns,
|
|
|
|
clippy::diverging_sub_expression
|
2019-12-26 22:42:28 -06:00
|
|
|
)]
|
2019-12-21 20:13:39 -06:00
|
|
|
|
|
|
|
use std::io::ErrorKind;
|
2019-09-21 00:26:18 -05:00
|
|
|
|
|
|
|
#[derive(Clone, Copy, Debug, Eq, PartialEq)]
|
|
|
|
enum Color {
|
|
|
|
Red,
|
|
|
|
Green,
|
|
|
|
Blue,
|
|
|
|
Rgb(u8, u8, u8),
|
|
|
|
Cyan,
|
|
|
|
}
|
|
|
|
|
|
|
|
impl Color {
|
|
|
|
fn is_monochrome(self) -> bool {
|
|
|
|
match self {
|
|
|
|
Color::Red | Color::Green | Color::Blue => true,
|
|
|
|
Color::Rgb(r, g, b) => r | g == 0 || r | b == 0 || g | b == 0,
|
|
|
|
Color::Cyan => false,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
let color = Color::Rgb(0, 0, 127);
|
|
|
|
match color {
|
|
|
|
Color::Red => println!("Red"),
|
|
|
|
Color::Green | Color::Blue | Color::Rgb(..) | Color::Cyan => eprintln!("Not red"),
|
|
|
|
};
|
|
|
|
match color {
|
|
|
|
Color::Red => println!("Red"),
|
|
|
|
_not_red @ Color::Green | _not_red @ Color::Blue | _not_red @ Color::Rgb(..) | _not_red @ Color::Cyan => eprintln!("Not red"),
|
|
|
|
};
|
|
|
|
let _str = match color {
|
|
|
|
Color::Red => "Red".to_owned(),
|
|
|
|
not_red @ Color::Green | not_red @ Color::Blue | not_red @ Color::Rgb(..) | not_red @ Color::Cyan => format!("{:?}", not_red),
|
|
|
|
};
|
|
|
|
match color {
|
|
|
|
Color::Red => {},
|
|
|
|
Color::Green => {},
|
|
|
|
Color::Blue => {},
|
|
|
|
Color::Cyan => {},
|
|
|
|
c if c.is_monochrome() => {},
|
|
|
|
Color::Rgb(_, _, _) => {},
|
|
|
|
};
|
|
|
|
let _str = match color {
|
|
|
|
Color::Red => "Red",
|
|
|
|
c @ Color::Green | c @ Color::Blue | c @ Color::Rgb(_, _, _) | c @ Color::Cyan => "Not red",
|
|
|
|
};
|
|
|
|
match color {
|
|
|
|
Color::Rgb(r, _, _) if r > 0 => "Some red",
|
|
|
|
Color::Red | Color::Green | Color::Blue | Color::Rgb(..) | Color::Cyan => "No red",
|
|
|
|
};
|
|
|
|
match color {
|
|
|
|
Color::Red | Color::Green | Color::Blue | Color::Cyan => {},
|
|
|
|
Color::Rgb(..) => {},
|
|
|
|
};
|
|
|
|
let x: u8 = unimplemented!();
|
|
|
|
match x {
|
|
|
|
0 => {},
|
|
|
|
140 => {},
|
|
|
|
_ => {},
|
|
|
|
};
|
2019-12-21 20:13:39 -06:00
|
|
|
// We need to use an enum not defined in this test because non_exhaustive is ignored for the
|
|
|
|
// purposes of dead code analysis within a crate.
|
|
|
|
let error_kind = ErrorKind::NotFound;
|
|
|
|
match error_kind {
|
|
|
|
ErrorKind::NotFound => {},
|
2021-03-25 13:29:11 -05:00
|
|
|
ErrorKind::PermissionDenied | ErrorKind::ConnectionRefused | ErrorKind::ConnectionReset | ErrorKind::ConnectionAborted | ErrorKind::NotConnected | ErrorKind::AddrInUse | ErrorKind::AddrNotAvailable | ErrorKind::BrokenPipe | ErrorKind::AlreadyExists | ErrorKind::WouldBlock | ErrorKind::InvalidInput | ErrorKind::InvalidData | ErrorKind::TimedOut | ErrorKind::WriteZero | ErrorKind::Interrupted | ErrorKind::Other | ErrorKind::UnexpectedEof | _ => {},
|
2019-12-21 20:13:39 -06:00
|
|
|
}
|
|
|
|
match error_kind {
|
|
|
|
ErrorKind::NotFound => {},
|
|
|
|
ErrorKind::PermissionDenied => {},
|
|
|
|
ErrorKind::ConnectionRefused => {},
|
|
|
|
ErrorKind::ConnectionReset => {},
|
|
|
|
ErrorKind::ConnectionAborted => {},
|
|
|
|
ErrorKind::NotConnected => {},
|
|
|
|
ErrorKind::AddrInUse => {},
|
|
|
|
ErrorKind::AddrNotAvailable => {},
|
|
|
|
ErrorKind::BrokenPipe => {},
|
|
|
|
ErrorKind::AlreadyExists => {},
|
|
|
|
ErrorKind::WouldBlock => {},
|
|
|
|
ErrorKind::InvalidInput => {},
|
|
|
|
ErrorKind::InvalidData => {},
|
|
|
|
ErrorKind::TimedOut => {},
|
|
|
|
ErrorKind::WriteZero => {},
|
|
|
|
ErrorKind::Interrupted => {},
|
|
|
|
ErrorKind::Other => {},
|
|
|
|
ErrorKind::UnexpectedEof => {},
|
|
|
|
_ => {},
|
|
|
|
}
|
2019-09-21 00:26:18 -05:00
|
|
|
}
|