mirror of
https://github.com/rust-lang/rust.git
synced 2026-04-27 18:57:42 +03:00
5830ca216d
It lints against features that are inteded to be internal to the compiler and standard library. Implements MCP #596. We allow `internal_features` in the standard library and compiler as those use many features and this _is_ the standard library from the "internal to the compiler and standard library" after all. Marking some features as internal wasn't exactly the most scientific approach, I just marked some mostly obvious features. While there is a categorization in the macro, it's not very well upheld (should probably be fixed in another PR). We always pass `-Ainternal_features` in the testsuite About 400 UI tests and several other tests use internal features. Instead of throwing the attribute on each one, just always allow them. There's nothing wrong with testing internal features^^
563 lines
21 KiB
Rust
563 lines
21 KiB
Rust
//! 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 user-defined lint plugins via the plugin mechanism.
|
|
//!
|
|
//! Some of rustc's lints are defined elsewhere in the compiler and work by
|
|
//! calling `add_lint()` on the overall `Session` object. This works when
|
|
//! it happens before the main lint pass, which emits the lints stored by
|
|
//! `add_lint()`. To emit lints after the main lint pass (from codegen, for
|
|
//! example) requires more effort. See `emit_lint` and `GatherNodeLevels`
|
|
//! in `context.rs`.
|
|
//!
|
|
//! Some code also exists in [rustc_session::lint], [rustc_middle::lint].
|
|
//!
|
|
//! ## Note
|
|
//!
|
|
//! This API is completely unstable and subject to change.
|
|
|
|
#![allow(rustc::potential_query_instability)]
|
|
#![doc(html_root_url = "https://doc.rust-lang.org/nightly/nightly-rustc/")]
|
|
#![feature(array_windows)]
|
|
#![feature(box_patterns)]
|
|
#![feature(control_flow_enum)]
|
|
#![feature(if_let_guard)]
|
|
#![feature(iter_intersperse)]
|
|
#![feature(iter_order_by)]
|
|
#![feature(let_chains)]
|
|
#![feature(min_specialization)]
|
|
#![feature(never_type)]
|
|
#![feature(rustc_attrs)]
|
|
#![recursion_limit = "256"]
|
|
#![deny(rustc::untranslatable_diagnostic)]
|
|
#![deny(rustc::diagnostic_outside_of_impl)]
|
|
#![cfg_attr(not(bootstrap), allow(internal_features))]
|
|
|
|
#[macro_use]
|
|
extern crate rustc_middle;
|
|
#[macro_use]
|
|
extern crate rustc_session;
|
|
#[macro_use]
|
|
extern crate tracing;
|
|
|
|
mod array_into_iter;
|
|
pub mod builtin;
|
|
mod context;
|
|
mod deref_into_dyn_supertrait;
|
|
mod drop_forget_useless;
|
|
mod early;
|
|
mod enum_intrinsics_non_enums;
|
|
mod errors;
|
|
mod expect;
|
|
mod fn_null_check;
|
|
mod for_loops_over_fallibles;
|
|
pub mod hidden_unicode_codepoints;
|
|
mod internal;
|
|
mod invalid_from_utf8;
|
|
mod late;
|
|
mod let_underscore;
|
|
mod levels;
|
|
mod lints;
|
|
mod map_unit_fn;
|
|
mod methods;
|
|
mod multiple_supertrait_upcastable;
|
|
mod non_ascii_idents;
|
|
mod non_fmt_panic;
|
|
mod nonstandard_style;
|
|
mod noop_method_call;
|
|
mod opaque_hidden_inferred_bound;
|
|
mod pass_by_value;
|
|
mod passes;
|
|
mod redundant_semicolon;
|
|
mod reference_casting;
|
|
mod traits;
|
|
mod types;
|
|
mod unused;
|
|
|
|
pub use array_into_iter::ARRAY_INTO_ITER;
|
|
|
|
use rustc_ast as ast;
|
|
use rustc_errors::{DiagnosticMessage, SubdiagnosticMessage};
|
|
use rustc_fluent_macro::fluent_messages;
|
|
use rustc_hir as hir;
|
|
use rustc_hir::def_id::LocalDefId;
|
|
use rustc_middle::query::Providers;
|
|
use rustc_middle::ty::TyCtxt;
|
|
use rustc_session::lint::builtin::{
|
|
BARE_TRAIT_OBJECTS, ELIDED_LIFETIMES_IN_PATHS, EXPLICIT_OUTLIVES_REQUIREMENTS,
|
|
};
|
|
use rustc_span::symbol::Ident;
|
|
use rustc_span::Span;
|
|
|
|
use array_into_iter::ArrayIntoIter;
|
|
use builtin::*;
|
|
use deref_into_dyn_supertrait::*;
|
|
use drop_forget_useless::*;
|
|
use enum_intrinsics_non_enums::EnumIntrinsicsNonEnums;
|
|
use fn_null_check::*;
|
|
use for_loops_over_fallibles::*;
|
|
use hidden_unicode_codepoints::*;
|
|
use internal::*;
|
|
use invalid_from_utf8::*;
|
|
use let_underscore::*;
|
|
use map_unit_fn::*;
|
|
use methods::*;
|
|
use multiple_supertrait_upcastable::*;
|
|
use non_ascii_idents::*;
|
|
use non_fmt_panic::NonPanicFmt;
|
|
use nonstandard_style::*;
|
|
use noop_method_call::*;
|
|
use opaque_hidden_inferred_bound::*;
|
|
use pass_by_value::*;
|
|
use redundant_semicolon::*;
|
|
use reference_casting::*;
|
|
use traits::*;
|
|
use types::*;
|
|
use unused::*;
|
|
|
|
/// Useful for other parts of the compiler / Clippy.
|
|
pub use builtin::SoftLints;
|
|
pub use context::{CheckLintNameResult, FindLintError, LintStore};
|
|
pub use context::{EarlyContext, LateContext, LintContext};
|
|
pub use early::{check_ast_node, EarlyCheckNode};
|
|
pub use late::{check_crate, unerased_lint_store};
|
|
pub use passes::{EarlyLintPass, LateLintPass};
|
|
pub use rustc_session::lint::Level::{self, *};
|
|
pub use rustc_session::lint::{BufferedEarlyLint, FutureIncompatibleInfo, Lint, LintId};
|
|
pub use rustc_session::lint::{LintArray, LintPass};
|
|
|
|
fluent_messages! { "../messages.ftl" }
|
|
|
|
pub fn provide(providers: &mut Providers) {
|
|
levels::provide(providers);
|
|
expect::provide(providers);
|
|
*providers = Providers { lint_mod, ..*providers };
|
|
}
|
|
|
|
fn lint_mod(tcx: TyCtxt<'_>, module_def_id: LocalDefId) {
|
|
late::late_lint_mod(tcx, module_def_id, BuiltinCombinedModuleLateLintPass::new());
|
|
}
|
|
|
|
early_lint_methods!(
|
|
declare_combined_early_lint_pass,
|
|
[
|
|
pub BuiltinCombinedPreExpansionLintPass,
|
|
[
|
|
KeywordIdents: KeywordIdents,
|
|
]
|
|
]
|
|
);
|
|
|
|
early_lint_methods!(
|
|
declare_combined_early_lint_pass,
|
|
[
|
|
pub BuiltinCombinedEarlyLintPass,
|
|
[
|
|
UnusedParens: UnusedParens::new(),
|
|
UnusedBraces: UnusedBraces,
|
|
UnusedImportBraces: UnusedImportBraces,
|
|
UnsafeCode: UnsafeCode,
|
|
SpecialModuleName: SpecialModuleName,
|
|
AnonymousParameters: AnonymousParameters,
|
|
EllipsisInclusiveRangePatterns: EllipsisInclusiveRangePatterns::default(),
|
|
NonCamelCaseTypes: NonCamelCaseTypes,
|
|
DeprecatedAttr: DeprecatedAttr::new(),
|
|
WhileTrue: WhileTrue,
|
|
NonAsciiIdents: NonAsciiIdents,
|
|
HiddenUnicodeCodepoints: HiddenUnicodeCodepoints,
|
|
IncompleteInternalFeatures: IncompleteInternalFeatures,
|
|
RedundantSemicolons: RedundantSemicolons,
|
|
UnusedDocComment: UnusedDocComment,
|
|
UnexpectedCfgs: UnexpectedCfgs,
|
|
]
|
|
]
|
|
);
|
|
|
|
// FIXME: Make a separate lint type which does not require typeck tables.
|
|
|
|
late_lint_methods!(
|
|
declare_combined_late_lint_pass,
|
|
[
|
|
pub BuiltinCombinedLateLintPass,
|
|
[
|
|
// Tracks state across modules
|
|
UnnameableTestItems: UnnameableTestItems::new(),
|
|
// Tracks attributes of parents
|
|
MissingDoc: MissingDoc::new(),
|
|
// Builds a global list of all impls of `Debug`.
|
|
// FIXME: Turn the computation of types which implement Debug into a query
|
|
// and change this to a module lint pass
|
|
MissingDebugImplementations: MissingDebugImplementations::default(),
|
|
// Keeps a global list of foreign declarations.
|
|
ClashingExternDeclarations: ClashingExternDeclarations::new(),
|
|
]
|
|
]
|
|
);
|
|
|
|
late_lint_methods!(
|
|
declare_combined_late_lint_pass,
|
|
[
|
|
BuiltinCombinedModuleLateLintPass,
|
|
[
|
|
ForLoopsOverFallibles: ForLoopsOverFallibles,
|
|
DerefIntoDynSupertrait: DerefIntoDynSupertrait,
|
|
DropForgetUseless: DropForgetUseless,
|
|
HardwiredLints: HardwiredLints,
|
|
ImproperCTypesDeclarations: ImproperCTypesDeclarations,
|
|
ImproperCTypesDefinitions: ImproperCTypesDefinitions,
|
|
InvalidFromUtf8: InvalidFromUtf8,
|
|
VariantSizeDifferences: VariantSizeDifferences,
|
|
BoxPointers: BoxPointers,
|
|
PathStatements: PathStatements,
|
|
LetUnderscore: LetUnderscore,
|
|
InvalidReferenceCasting: InvalidReferenceCasting::default(),
|
|
// Depends on referenced function signatures in expressions
|
|
UnusedResults: UnusedResults,
|
|
NonUpperCaseGlobals: NonUpperCaseGlobals,
|
|
NonShorthandFieldPatterns: NonShorthandFieldPatterns,
|
|
UnusedAllocation: UnusedAllocation,
|
|
// Depends on types used in type definitions
|
|
MissingCopyImplementations: MissingCopyImplementations,
|
|
// Depends on referenced function signatures in expressions
|
|
IncorrectFnNullChecks: IncorrectFnNullChecks,
|
|
MutableTransmutes: MutableTransmutes,
|
|
TypeAliasBounds: TypeAliasBounds,
|
|
TrivialConstraints: TrivialConstraints,
|
|
TypeLimits: TypeLimits::new(),
|
|
NonSnakeCase: NonSnakeCase,
|
|
InvalidNoMangleItems: InvalidNoMangleItems,
|
|
// Depends on effective visibilities
|
|
UnreachablePub: UnreachablePub,
|
|
ExplicitOutlivesRequirements: ExplicitOutlivesRequirements,
|
|
InvalidValue: InvalidValue,
|
|
DerefNullPtr: DerefNullPtr,
|
|
// May Depend on constants elsewhere
|
|
UnusedBrokenConst: UnusedBrokenConst,
|
|
UnstableFeatures: UnstableFeatures,
|
|
UngatedAsyncFnTrackCaller: UngatedAsyncFnTrackCaller,
|
|
ArrayIntoIter: ArrayIntoIter::default(),
|
|
DropTraitConstraints: DropTraitConstraints,
|
|
TemporaryCStringAsPtr: TemporaryCStringAsPtr,
|
|
NonPanicFmt: NonPanicFmt,
|
|
NoopMethodCall: NoopMethodCall,
|
|
EnumIntrinsicsNonEnums: EnumIntrinsicsNonEnums,
|
|
InvalidAtomicOrdering: InvalidAtomicOrdering,
|
|
NamedAsmLabels: NamedAsmLabels,
|
|
OpaqueHiddenInferredBound: OpaqueHiddenInferredBound,
|
|
MultipleSupertraitUpcastable: MultipleSupertraitUpcastable,
|
|
MapUnitFn: MapUnitFn,
|
|
]
|
|
]
|
|
);
|
|
|
|
pub fn new_lint_store(internal_lints: bool) -> LintStore {
|
|
let mut lint_store = LintStore::new();
|
|
|
|
register_builtins(&mut lint_store);
|
|
if internal_lints {
|
|
register_internals(&mut lint_store);
|
|
}
|
|
|
|
lint_store
|
|
}
|
|
|
|
/// Tell the `LintStore` about all the built-in lints (the ones
|
|
/// defined in this crate and the ones defined in
|
|
/// `rustc_session::lint::builtin`).
|
|
fn register_builtins(store: &mut LintStore) {
|
|
macro_rules! add_lint_group {
|
|
($name:expr, $($lint:ident),*) => (
|
|
store.register_group(false, $name, None, vec![$(LintId::of($lint)),*]);
|
|
)
|
|
}
|
|
|
|
store.register_lints(&BuiltinCombinedPreExpansionLintPass::get_lints());
|
|
store.register_lints(&BuiltinCombinedEarlyLintPass::get_lints());
|
|
store.register_lints(&BuiltinCombinedModuleLateLintPass::get_lints());
|
|
store.register_lints(&BuiltinCombinedLateLintPass::get_lints());
|
|
|
|
add_lint_group!(
|
|
"nonstandard_style",
|
|
NON_CAMEL_CASE_TYPES,
|
|
NON_SNAKE_CASE,
|
|
NON_UPPER_CASE_GLOBALS
|
|
);
|
|
|
|
add_lint_group!(
|
|
"unused",
|
|
UNUSED_IMPORTS,
|
|
UNUSED_VARIABLES,
|
|
UNUSED_ASSIGNMENTS,
|
|
DEAD_CODE,
|
|
UNUSED_MUT,
|
|
UNREACHABLE_CODE,
|
|
UNREACHABLE_PATTERNS,
|
|
UNUSED_MUST_USE,
|
|
UNUSED_UNSAFE,
|
|
PATH_STATEMENTS,
|
|
UNUSED_ATTRIBUTES,
|
|
UNUSED_MACROS,
|
|
UNUSED_MACRO_RULES,
|
|
UNUSED_ALLOCATION,
|
|
UNUSED_DOC_COMMENTS,
|
|
UNUSED_EXTERN_CRATES,
|
|
UNUSED_FEATURES,
|
|
UNUSED_LABELS,
|
|
UNUSED_PARENS,
|
|
UNUSED_BRACES,
|
|
REDUNDANT_SEMICOLONS,
|
|
MAP_UNIT_FN
|
|
);
|
|
|
|
add_lint_group!("let_underscore", LET_UNDERSCORE_DROP, LET_UNDERSCORE_LOCK);
|
|
|
|
add_lint_group!(
|
|
"rust_2018_idioms",
|
|
BARE_TRAIT_OBJECTS,
|
|
UNUSED_EXTERN_CRATES,
|
|
ELLIPSIS_INCLUSIVE_RANGE_PATTERNS,
|
|
ELIDED_LIFETIMES_IN_PATHS,
|
|
EXPLICIT_OUTLIVES_REQUIREMENTS // FIXME(#52665, #47816) not always applicable and not all
|
|
// macros are ready for this yet.
|
|
// UNREACHABLE_PUB,
|
|
|
|
// FIXME macro crates are not up for this yet, too much
|
|
// breakage is seen if we try to encourage this lint.
|
|
// MACRO_USE_EXTERN_CRATE
|
|
);
|
|
|
|
// Register renamed and removed lints.
|
|
store.register_renamed("single_use_lifetime", "single_use_lifetimes");
|
|
store.register_renamed("elided_lifetime_in_path", "elided_lifetimes_in_paths");
|
|
store.register_renamed("bare_trait_object", "bare_trait_objects");
|
|
store.register_renamed("unstable_name_collision", "unstable_name_collisions");
|
|
store.register_renamed("unused_doc_comment", "unused_doc_comments");
|
|
store.register_renamed("async_idents", "keyword_idents");
|
|
store.register_renamed("exceeding_bitshifts", "arithmetic_overflow");
|
|
store.register_renamed("redundant_semicolon", "redundant_semicolons");
|
|
store.register_renamed("overlapping_patterns", "overlapping_range_endpoints");
|
|
store.register_renamed("disjoint_capture_migration", "rust_2021_incompatible_closure_captures");
|
|
store.register_renamed("or_patterns_back_compat", "rust_2021_incompatible_or_patterns");
|
|
store.register_renamed("non_fmt_panic", "non_fmt_panics");
|
|
|
|
// These were moved to tool lints, but rustc still sees them when compiling normally, before
|
|
// tool lints are registered, so `check_tool_name_for_backwards_compat` doesn't work. Use
|
|
// `register_removed` explicitly.
|
|
const RUSTDOC_LINTS: &[&str] = &[
|
|
"broken_intra_doc_links",
|
|
"private_intra_doc_links",
|
|
"missing_crate_level_docs",
|
|
"missing_doc_code_examples",
|
|
"private_doc_tests",
|
|
"invalid_codeblock_attributes",
|
|
"invalid_html_tags",
|
|
"non_autolinks",
|
|
];
|
|
for rustdoc_lint in RUSTDOC_LINTS {
|
|
store.register_ignored(rustdoc_lint);
|
|
}
|
|
store.register_removed(
|
|
"intra_doc_link_resolution_failure",
|
|
"use `rustdoc::broken_intra_doc_links` instead",
|
|
);
|
|
store.register_removed("rustdoc", "use `rustdoc::all` instead");
|
|
|
|
store.register_removed("unknown_features", "replaced by an error");
|
|
store.register_removed("unsigned_negation", "replaced by negate_unsigned feature gate");
|
|
store.register_removed("negate_unsigned", "cast a signed value instead");
|
|
store.register_removed("raw_pointer_derive", "using derive with raw pointers is ok");
|
|
// Register lint group aliases.
|
|
store.register_group_alias("nonstandard_style", "bad_style");
|
|
// This was renamed to `raw_pointer_derive`, which was then removed,
|
|
// so it is also considered removed.
|
|
store.register_removed("raw_pointer_deriving", "using derive with raw pointers is ok");
|
|
store.register_removed("drop_with_repr_extern", "drop flags have been removed");
|
|
store.register_removed("fat_ptr_transmutes", "was accidentally removed back in 2014");
|
|
store.register_removed("deprecated_attr", "use `deprecated` instead");
|
|
store.register_removed(
|
|
"transmute_from_fn_item_types",
|
|
"always cast functions before transmuting them",
|
|
);
|
|
store.register_removed(
|
|
"hr_lifetime_in_assoc_type",
|
|
"converted into hard error, see issue #33685 \
|
|
<https://github.com/rust-lang/rust/issues/33685> for more information",
|
|
);
|
|
store.register_removed(
|
|
"inaccessible_extern_crate",
|
|
"converted into hard error, see issue #36886 \
|
|
<https://github.com/rust-lang/rust/issues/36886> for more information",
|
|
);
|
|
store.register_removed(
|
|
"super_or_self_in_global_path",
|
|
"converted into hard error, see issue #36888 \
|
|
<https://github.com/rust-lang/rust/issues/36888> for more information",
|
|
);
|
|
store.register_removed(
|
|
"overlapping_inherent_impls",
|
|
"converted into hard error, see issue #36889 \
|
|
<https://github.com/rust-lang/rust/issues/36889> for more information",
|
|
);
|
|
store.register_removed(
|
|
"illegal_floating_point_constant_pattern",
|
|
"converted into hard error, see issue #36890 \
|
|
<https://github.com/rust-lang/rust/issues/36890> for more information",
|
|
);
|
|
store.register_removed(
|
|
"illegal_struct_or_enum_constant_pattern",
|
|
"converted into hard error, see issue #36891 \
|
|
<https://github.com/rust-lang/rust/issues/36891> for more information",
|
|
);
|
|
store.register_removed(
|
|
"lifetime_underscore",
|
|
"converted into hard error, see issue #36892 \
|
|
<https://github.com/rust-lang/rust/issues/36892> for more information",
|
|
);
|
|
store.register_removed(
|
|
"extra_requirement_in_impl",
|
|
"converted into hard error, see issue #37166 \
|
|
<https://github.com/rust-lang/rust/issues/37166> for more information",
|
|
);
|
|
store.register_removed(
|
|
"legacy_imports",
|
|
"converted into hard error, see issue #38260 \
|
|
<https://github.com/rust-lang/rust/issues/38260> for more information",
|
|
);
|
|
store.register_removed(
|
|
"coerce_never",
|
|
"converted into hard error, see issue #48950 \
|
|
<https://github.com/rust-lang/rust/issues/48950> for more information",
|
|
);
|
|
store.register_removed(
|
|
"resolve_trait_on_defaulted_unit",
|
|
"converted into hard error, see issue #48950 \
|
|
<https://github.com/rust-lang/rust/issues/48950> for more information",
|
|
);
|
|
store.register_removed(
|
|
"private_no_mangle_fns",
|
|
"no longer a warning, `#[no_mangle]` functions always exported",
|
|
);
|
|
store.register_removed(
|
|
"private_no_mangle_statics",
|
|
"no longer a warning, `#[no_mangle]` statics always exported",
|
|
);
|
|
store.register_removed("bad_repr", "replaced with a generic attribute input check");
|
|
store.register_removed(
|
|
"duplicate_matcher_binding_name",
|
|
"converted into hard error, see issue #57742 \
|
|
<https://github.com/rust-lang/rust/issues/57742> for more information",
|
|
);
|
|
store.register_removed(
|
|
"incoherent_fundamental_impls",
|
|
"converted into hard error, see issue #46205 \
|
|
<https://github.com/rust-lang/rust/issues/46205> for more information",
|
|
);
|
|
store.register_removed(
|
|
"legacy_constructor_visibility",
|
|
"converted into hard error, see issue #39207 \
|
|
<https://github.com/rust-lang/rust/issues/39207> for more information",
|
|
);
|
|
store.register_removed(
|
|
"legacy_directory_ownership",
|
|
"converted into hard error, see issue #37872 \
|
|
<https://github.com/rust-lang/rust/issues/37872> for more information",
|
|
);
|
|
store.register_removed(
|
|
"safe_extern_statics",
|
|
"converted into hard error, see issue #36247 \
|
|
<https://github.com/rust-lang/rust/issues/36247> for more information",
|
|
);
|
|
store.register_removed(
|
|
"parenthesized_params_in_types_and_modules",
|
|
"converted into hard error, see issue #42238 \
|
|
<https://github.com/rust-lang/rust/issues/42238> for more information",
|
|
);
|
|
store.register_removed(
|
|
"duplicate_macro_exports",
|
|
"converted into hard error, see issue #35896 \
|
|
<https://github.com/rust-lang/rust/issues/35896> for more information",
|
|
);
|
|
store.register_removed(
|
|
"nested_impl_trait",
|
|
"converted into hard error, see issue #59014 \
|
|
<https://github.com/rust-lang/rust/issues/59014> for more information",
|
|
);
|
|
store.register_removed("plugin_as_library", "plugins have been deprecated and retired");
|
|
store.register_removed(
|
|
"unsupported_naked_functions",
|
|
"converted into hard error, see RFC 2972 \
|
|
<https://github.com/rust-lang/rfcs/blob/master/text/2972-constrained-naked.md> for more information",
|
|
);
|
|
store.register_removed(
|
|
"mutable_borrow_reservation_conflict",
|
|
"now allowed, see issue #59159 \
|
|
<https://github.com/rust-lang/rust/issues/59159> for more information",
|
|
);
|
|
store.register_removed(
|
|
"const_err",
|
|
"converted into hard error, see issue #71800 \
|
|
<https://github.com/rust-lang/rust/issues/71800> for more information",
|
|
);
|
|
store.register_removed(
|
|
"safe_packed_borrows",
|
|
"converted into hard error, see issue #82523 \
|
|
<https://github.com/rust-lang/rust/issues/82523> for more information",
|
|
);
|
|
store.register_removed(
|
|
"unaligned_references",
|
|
"converted into hard error, see issue #82523 \
|
|
<https://github.com/rust-lang/rust/issues/82523> for more information",
|
|
);
|
|
}
|
|
|
|
fn register_internals(store: &mut LintStore) {
|
|
store.register_lints(&LintPassImpl::get_lints());
|
|
store.register_early_pass(|| Box::new(LintPassImpl));
|
|
store.register_lints(&DefaultHashTypes::get_lints());
|
|
store.register_late_pass(|_| Box::new(DefaultHashTypes));
|
|
store.register_lints(&QueryStability::get_lints());
|
|
store.register_late_pass(|_| Box::new(QueryStability));
|
|
store.register_lints(&ExistingDocKeyword::get_lints());
|
|
store.register_late_pass(|_| Box::new(ExistingDocKeyword));
|
|
store.register_lints(&TyTyKind::get_lints());
|
|
store.register_late_pass(|_| Box::new(TyTyKind));
|
|
store.register_lints(&Diagnostics::get_lints());
|
|
store.register_early_pass(|| Box::new(Diagnostics));
|
|
store.register_late_pass(|_| Box::new(Diagnostics));
|
|
store.register_lints(&BadOptAccess::get_lints());
|
|
store.register_late_pass(|_| Box::new(BadOptAccess));
|
|
store.register_lints(&PassByValue::get_lints());
|
|
store.register_late_pass(|_| Box::new(PassByValue));
|
|
// FIXME(davidtwco): deliberately do not include `UNTRANSLATABLE_DIAGNOSTIC` and
|
|
// `DIAGNOSTIC_OUTSIDE_OF_IMPL` here because `-Wrustc::internal` is provided to every crate and
|
|
// these lints will trigger all of the time - change this once migration to diagnostic structs
|
|
// and translation is completed
|
|
store.register_group(
|
|
false,
|
|
"rustc::internal",
|
|
None,
|
|
vec![
|
|
LintId::of(DEFAULT_HASH_TYPES),
|
|
LintId::of(POTENTIAL_QUERY_INSTABILITY),
|
|
LintId::of(USAGE_OF_TY_TYKIND),
|
|
LintId::of(PASS_BY_VALUE),
|
|
LintId::of(LINT_PASS_IMPL_WITHOUT_MACRO),
|
|
LintId::of(USAGE_OF_QUALIFIED_TY),
|
|
LintId::of(EXISTING_DOC_KEYWORD),
|
|
LintId::of(BAD_OPT_ACCESS),
|
|
],
|
|
);
|
|
}
|
|
|
|
#[cfg(test)]
|
|
mod tests;
|