rust/book/src
2025-01-28 19:14:45 +01:00
..
continuous_integration Merge commit '26ac6aab02' 2024-01-11 17:27:03 +01:00
development Select Rust edition 2024 for compiling Clippy (#13751) 2025-01-13 18:05:05 +00:00
attribs.md Merge commit 'ff4a26d442' into clippy-subtree-update 2024-11-28 19:38:59 +01:00
configuration.md Merge commit '3e5a02b13b' into clippy-subtree-update 2024-06-13 12:30:48 +02:00
installation.md Merge commit '83e42a2337' into clippyup 2023-04-11 15:31:08 +02:00
lint_configuration.md fixed a missing description of the MSRV option for manual_repeat_n 2025-01-27 04:54:40 +09:00
lints.md Merge commit '83e42a2337' into clippyup 2023-04-11 15:31:08 +02:00
README.md Merge commit 'f712eb5cdc' into clippy-subtree-update 2024-11-07 22:37:01 +01:00
SUMMARY.md Merge commit 'ff4a26d442' into clippy-subtree-update 2024-11-28 19:38:59 +01:00
usage.md remove clippy::double_neg 2025-01-26 12:15:12 +01:00

Clippy

License: MIT OR Apache-2.0

A collection of lints to catch common mistakes and improve your Rust code.

There are over 750 lints included in this crate!

Lints are divided into categories, each with a default lint level. You can choose how much Clippy is supposed to annoy help you by changing the lint level by category.

Category Description Default level
clippy::all all lints that are on by default (correctness, suspicious, style, complexity, perf) warn/deny
clippy::correctness code that is outright wrong or useless deny
clippy::suspicious code that is most likely wrong or useless warn
clippy::style code that should be written in a more idiomatic way warn
clippy::complexity code that does something simple but in a complex way warn
clippy::perf code that can be written to run faster warn
clippy::pedantic lints which are rather strict or have occasional false positives allow
clippy::restriction lints which prevent the use of language and library features1 allow
clippy::nursery new lints that are still under development allow
clippy::cargo lints for the cargo manifest allow

More to come, please file an issue if you have ideas!

The restriction category should, emphatically, not be enabled as a whole. The contained lints may lint against perfectly reasonable code, may not have an alternative suggestion, and may contradict any other lints (including other categories). Lints should be considered on a case-by-case basis before enabling.


  1. Some use cases for restriction lints include:

    ↩︎