mirror of
https://github.com/rust-lang/rust-clippy
synced 2025-01-12 13:18:43 +00:00
8b02dac542
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
61 lines
1.3 KiB
Rust
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
|
|
_ => {},
|
|
}
|
|
}
|