2023-10-03 06:36:35 -05:00
|
|
|
//@aux-build:proc_macro_derive.rs
|
2023-07-27 12:04:01 -05:00
|
|
|
#![warn(clippy::ignored_unit_patterns)]
|
2023-11-14 21:41:38 -06:00
|
|
|
#![allow(
|
|
|
|
clippy::let_unit_value,
|
|
|
|
clippy::redundant_pattern_matching,
|
|
|
|
clippy::single_match,
|
|
|
|
clippy::needless_borrow
|
|
|
|
)]
|
2023-07-27 12:04:01 -05:00
|
|
|
|
|
|
|
fn foo() -> Result<(), ()> {
|
|
|
|
unimplemented!()
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
match foo() {
|
2023-09-04 10:04:04 -05:00
|
|
|
Ok(()) => {}, //~ ERROR: matching over `()` is more explicit
|
|
|
|
Err(()) => {}, //~ ERROR: matching over `()` is more explicit
|
2023-07-27 12:04:01 -05:00
|
|
|
}
|
|
|
|
if let Ok(()) = foo() {}
|
2023-09-04 10:04:04 -05:00
|
|
|
//~^ ERROR: matching over `()` is more explicit
|
2023-07-27 12:04:01 -05:00
|
|
|
let _ = foo().map_err(|()| todo!());
|
2023-09-04 10:04:04 -05:00
|
|
|
//~^ ERROR: matching over `()` is more explicit
|
2023-10-03 06:36:35 -05:00
|
|
|
|
|
|
|
println!(
|
|
|
|
"{:?}",
|
|
|
|
match foo() {
|
|
|
|
Ok(()) => {},
|
|
|
|
//~^ ERROR: matching over `()` is more explicit
|
|
|
|
Err(()) => {},
|
|
|
|
//~^ ERROR: matching over `()` is more explicit
|
|
|
|
}
|
|
|
|
);
|
2023-07-27 12:04:01 -05:00
|
|
|
}
|
2023-09-02 16:06:16 -05:00
|
|
|
|
2023-10-03 06:36:35 -05:00
|
|
|
// ignored_unit_patterns in derive macro should be ok
|
|
|
|
#[derive(proc_macro_derive::StructIgnoredUnitPattern)]
|
|
|
|
pub struct B;
|
|
|
|
|
2023-09-02 16:06:16 -05:00
|
|
|
#[allow(unused)]
|
|
|
|
pub fn moo(_: ()) {
|
|
|
|
let () = foo().unwrap();
|
|
|
|
//~^ ERROR: matching over `()` is more explicit
|
|
|
|
let _: () = foo().unwrap();
|
|
|
|
let _: () = ();
|
|
|
|
}
|
2023-10-14 19:40:47 -05:00
|
|
|
|
|
|
|
fn test_unit_ref_1() {
|
|
|
|
let x: (usize, &&&&&()) = (1, &&&&&&());
|
|
|
|
match x {
|
|
|
|
(1, ()) => unimplemented!(),
|
|
|
|
//~^ ERROR: matching over `()` is more explicit
|
|
|
|
_ => unimplemented!(),
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
fn test_unit_ref_2(v: &[(usize, ())]) {
|
|
|
|
for (x, ()) in v {
|
|
|
|
//~^ ERROR: matching over `()` is more explicit
|
|
|
|
let _ = x;
|
|
|
|
}
|
|
|
|
}
|