Expand description
Lints, aka compiler warnings.
A ‘lint’ check is a kind of miscellaneous constraint that a user might want to enforce, but might reasonably want to permit as well, on a module-by-module basis. They contrast with static constraints enforced by other phases of the compiler, which are generally required to hold in order to compile the program at all.
Most lints can be written as LintPass
instances. These run after
all other analyses. The LintPass
es built into rustc are defined
within [rustc_session::lint::builtin],
which has further comments on how to add such a lint.
rustc can also load external lint plugins, as is done for Clippy.
See https://rustc-dev-guide.rust-lang.org/diagnostics.html for an overview of how lints are implemented.
§Note
This API is completely unstable and subject to change.
Re-exports§
pub use builtin::MissingDoc;
pub use builtin::SoftLints;
pub use rustc_session::lint::Level::*;
Modules§
- Lints in the Rust compiler.
- context 🔒Basic types for managing and implementing lints.
- dangling 🔒
- early 🔒Implementation of the early lint pass.
- errors 🔒
- expect 🔒
- internal 🔒Some lints that are only useful in the compiler or crates that use compiler internals, such as Clippy.
- late 🔒Implementation of the late lint pass.
- levels 🔒
- lints 🔒
- Migration code for the
expr_fragment_specifier_2024
rule. - passes 🔒
- traits 🔒
- types 🔒
- unused 🔒
Macros§
- Combines multiple lints passes into a single lint pass, at compile time, for maximum speed. Each
check_foo
method in$methods
within this pass simply callscheck_foo
once per$pass
. Compare withEarlyLintPassObjects
, which is similar, but combines lint passes at runtime. - Combines multiple lints passes into a single lint pass, at compile time, for maximum speed. Each
check_foo
method in$methods
within this pass simply callscheck_foo
once per$pass
. Compare withLateLintPassObjects
, which is similar, but combines lint passes at runtime.
Structs§
- Lints that are buffered up early on in the
Session
before theLintLevels
is calculated. - Context for lint checking of the AST, after expansion, before lowering to HIR.
- Extra information for a future incompatibility lint.
- Context for lint checking outside of type inference.
- Specification of a single lint.
- Identifies a lint known to the compiler.
- Information about the registered lints.
Enums§
- Setting for how to handle a lint.
Statics§
- The
array_into_iter
lint detects callinginto_iter
on arrays. - The
boxed_slice_into_iter
lint detects callinginto_iter
on boxed slices. - Raw content of Fluent resource for this crate, generated by
fluent_messages
macro, imported byrustc_driver
to include all crates’ resources in one bundle.
Traits§
- Early lints work on different nodes - either on the crate root, or on freshly loaded modules. This trait generalizes over those nodes.
Functions§
- Performs lint checking on a crate.
- lint_
mod 🔒 - Tell the
LintStore
about all the built-in lints (the ones defined in this crate and the ones defined inrustc_session::lint::builtin
). - Extract the
LintStore
from [Session
].