rust/tests/ui/redundant_pattern_matching_poll.rs
Christiaan Dirkx 5a83968877 Change redundant_pattern_matching to also lint std::task::Poll
Suggest using utility methods `is_pending` and `is_ready`.
2020-11-17 23:40:31 +01:00

89 lines
1.5 KiB
Rust

// run-rustfix
#![warn(clippy::all)]
#![warn(clippy::redundant_pattern_matching)]
#![allow(unused_must_use, clippy::needless_bool, clippy::match_like_matches_macro)]
use std::task::Poll::{self, Pending, Ready};
fn main() {
if let Pending = Pending::<()> {}
if let Ready(_) = Ready(42) {}
if let Ready(_) = Ready(42) {
foo();
} else {
bar();
}
while let Ready(_) = Ready(42) {}
while let Pending = Ready(42) {}
while let Pending = Pending::<()> {}
if Pending::<i32>.is_pending() {}
if Ready(42).is_ready() {}
match Ready(42) {
Ready(_) => true,
Pending => false,
};
match Pending::<()> {
Ready(_) => false,
Pending => true,
};
let _ = match Pending::<()> {
Ready(_) => false,
Pending => true,
};
let poll = Ready(false);
let x = if let Ready(_) = poll { true } else { false };
takes_poll(x);
poll_const();
let _ = if let Ready(_) = gen_poll() {
1
} else if let Pending = gen_poll() {
2
} else {
3
};
}
fn gen_poll() -> Poll<()> {
Pending
}
fn takes_poll(_: bool) {}
fn foo() {}
fn bar() {}
const fn poll_const() {
if let Ready(_) = Ready(42) {}
if let Pending = Pending::<()> {}
while let Ready(_) = Ready(42) {}
while let Pending = Pending::<()> {}
match Ready(42) {
Ready(_) => true,
Pending => false,
};
match Pending::<()> {
Ready(_) => false,
Pending => true,
};
}