rust-clippy/tests/ui/rest_pat_in_fully_bound_structs.rs
jonboh 8b02dac542 add lint for struct field names
side effect for `enum_variants`:
use .first() instead of .get(0) in enum_variants lint
move to_camel_case to str_util module
move module, enum and struct name repetitions check to a single file `item_name_repetitions`
rename enum_variants threshold config option
2023-10-18 19:20:08 +02:00

61 lines
1.3 KiB
Rust

#![warn(clippy::rest_pat_in_fully_bound_structs)]
#![allow(clippy::struct_field_names)]
struct A {
a: i32,
b: i64,
c: &'static str,
}
macro_rules! foo {
($param:expr) => {
match $param {
A { a: 0, b: 0, c: "", .. } => {},
_ => {},
}
};
}
fn main() {
let a_struct = A { a: 5, b: 42, c: "A" };
match a_struct {
A { a: 5, b: 42, c: "", .. } => {}, // Lint
//~^ ERROR: unnecessary use of `..` pattern in struct binding. All fields were alr
A { a: 0, b: 0, c: "", .. } => {}, // Lint
//~^ ERROR: unnecessary use of `..` pattern in struct binding. All fields were alr
_ => {},
}
match a_struct {
A { a: 5, b: 42, .. } => {},
A { a: 0, b: 0, c: "", .. } => {}, // Lint
//~^ ERROR: unnecessary use of `..` pattern in struct binding. All fields were alr
_ => {},
}
// No lint
match a_struct {
A { a: 5, .. } => {},
A { a: 0, b: 0, .. } => {},
_ => {},
}
// No lint
foo!(a_struct);
#[non_exhaustive]
struct B {
a: u32,
b: u32,
c: u64,
}
let b_struct = B { a: 5, b: 42, c: 342 };
match b_struct {
B { a: 5, b: 42, .. } => {},
B { a: 0, b: 0, c: 128, .. } => {}, // No Lint
_ => {},
}
}