]> git.lizzy.rs Git - rust.git/blob - clippy_lints/src/lib.rs
Auto merge of #4372 - phansch:changelog_update, r=flip1995
[rust.git] / clippy_lints / src / lib.rs
1 // error-pattern:cargo-clippy
2
3 #![feature(box_syntax)]
4 #![feature(box_patterns)]
5 #![feature(never_type)]
6 #![feature(rustc_private)]
7 #![feature(slice_patterns)]
8 #![feature(stmt_expr_attributes)]
9 #![allow(clippy::missing_docs_in_private_items)]
10 #![recursion_limit = "512"]
11 #![warn(rust_2018_idioms, trivial_casts, trivial_numeric_casts)]
12 #![deny(rustc::internal)]
13 #![cfg_attr(feature = "deny-warnings", deny(warnings))]
14 #![feature(crate_visibility_modifier)]
15 #![feature(concat_idents)]
16
17 // FIXME: switch to something more ergonomic here, once available.
18 // (Currently there is no way to opt into sysroot crates without `extern crate`.)
19 #[allow(unused_extern_crates)]
20 extern crate fmt_macros;
21 #[allow(unused_extern_crates)]
22 extern crate rustc;
23 #[allow(unused_extern_crates)]
24 extern crate rustc_data_structures;
25 #[allow(unused_extern_crates)]
26 extern crate rustc_driver;
27 #[allow(unused_extern_crates)]
28 extern crate rustc_errors;
29 #[allow(unused_extern_crates)]
30 extern crate rustc_mir;
31 #[allow(unused_extern_crates)]
32 extern crate rustc_target;
33 #[allow(unused_extern_crates)]
34 extern crate rustc_typeck;
35 #[allow(unused_extern_crates)]
36 extern crate syntax;
37 #[allow(unused_extern_crates)]
38 extern crate syntax_pos;
39
40 use toml;
41
42 /// Macro used to declare a Clippy lint.
43 ///
44 /// Every lint declaration consists of 4 parts:
45 ///
46 /// 1. The documentation, which is used for the website
47 /// 2. The `LINT_NAME`. See [lint naming][lint_naming] on lint naming conventions.
48 /// 3. The `lint_level`, which is a mapping from *one* of our lint groups to `Allow`, `Warn` or
49 ///    `Deny`. The lint level here has nothing to do with what lint groups the lint is a part of.
50 /// 4. The `description` that contains a short explanation on what's wrong with code where the
51 ///    lint is triggered.
52 ///
53 /// Currently the categories `style`, `correctness`, `complexity` and `perf` are enabled by default.
54 /// As said in the README.md of this repository, if the lint level mapping changes, please update
55 /// README.md.
56 ///
57 /// # Example
58 ///
59 /// ```
60 /// # #![feature(rustc_private)]
61 /// # #[allow(unused_extern_crates)]
62 /// # extern crate rustc;
63 /// # #[macro_use]
64 /// # use clippy_lints::declare_clippy_lint;
65 /// use rustc::declare_tool_lint;
66 ///
67 /// declare_clippy_lint! {
68 ///     /// **What it does:** Checks for ... (describe what the lint matches).
69 ///     ///
70 ///     /// **Why is this bad?** Supply the reason for linting the code.
71 ///     ///
72 ///     /// **Known problems:** None. (Or describe where it could go wrong.)
73 ///     ///
74 ///     /// **Example:**
75 ///     ///
76 ///     /// ```rust
77 ///     /// // Bad
78 ///     /// Insert a short example of code that triggers the lint
79 ///     ///
80 ///     /// // Good
81 ///     /// Insert a short example of improved code that doesn't trigger the lint
82 ///     /// ```
83 ///     pub LINT_NAME,
84 ///     pedantic,
85 ///     "description"
86 /// }
87 /// ```
88 /// [lint_naming]: https://rust-lang.github.io/rfcs/0344-conventions-galore.html#lints
89 #[macro_export]
90 macro_rules! declare_clippy_lint {
91     { $(#[$attr:meta])* pub $name:tt, style, $description:tt } => {
92         declare_tool_lint! {
93             $(#[$attr])* pub clippy::$name, Warn, $description, report_in_external_macro: true
94         }
95     };
96     { $(#[$attr:meta])* pub $name:tt, correctness, $description:tt } => {
97         declare_tool_lint! {
98             $(#[$attr])* pub clippy::$name, Deny, $description, report_in_external_macro: true
99         }
100     };
101     { $(#[$attr:meta])* pub $name:tt, complexity, $description:tt } => {
102         declare_tool_lint! {
103             $(#[$attr])* pub clippy::$name, Warn, $description, report_in_external_macro: true
104         }
105     };
106     { $(#[$attr:meta])* pub $name:tt, perf, $description:tt } => {
107         declare_tool_lint! {
108             $(#[$attr])* pub clippy::$name, Warn, $description, report_in_external_macro: true
109         }
110     };
111     { $(#[$attr:meta])* pub $name:tt, pedantic, $description:tt } => {
112         declare_tool_lint! {
113             $(#[$attr])* pub clippy::$name, Allow, $description, report_in_external_macro: true
114         }
115     };
116     { $(#[$attr:meta])* pub $name:tt, restriction, $description:tt } => {
117         declare_tool_lint! {
118             $(#[$attr])* pub clippy::$name, Allow, $description, report_in_external_macro: true
119         }
120     };
121     { $(#[$attr:meta])* pub $name:tt, cargo, $description:tt } => {
122         declare_tool_lint! {
123             $(#[$attr])* pub clippy::$name, Allow, $description, report_in_external_macro: true
124         }
125     };
126     { $(#[$attr:meta])* pub $name:tt, nursery, $description:tt } => {
127         declare_tool_lint! {
128             $(#[$attr])* pub clippy::$name, Allow, $description, report_in_external_macro: true
129         }
130     };
131     { $(#[$attr:meta])* pub $name:tt, internal, $description:tt } => {
132         declare_tool_lint! {
133             $(#[$attr])* pub clippy::$name, Allow, $description, report_in_external_macro: true
134         }
135     };
136     { $(#[$attr:meta])* pub $name:tt, internal_warn, $description:tt } => {
137         declare_tool_lint! {
138             $(#[$attr])* pub clippy::$name, Warn, $description, report_in_external_macro: true
139         }
140     };
141 }
142
143 mod consts;
144 #[macro_use]
145 mod utils;
146
147 // begin lints modules, do not remove this comment, it’s used in `update_lints`
148 pub mod approx_const;
149 pub mod arithmetic;
150 pub mod assertions_on_constants;
151 pub mod assign_ops;
152 pub mod attrs;
153 pub mod bit_mask;
154 pub mod blacklisted_name;
155 pub mod block_in_if_condition;
156 pub mod booleans;
157 pub mod bytecount;
158 pub mod cargo_common_metadata;
159 pub mod checked_conversions;
160 pub mod cognitive_complexity;
161 pub mod collapsible_if;
162 pub mod copies;
163 pub mod copy_iterator;
164 pub mod dbg_macro;
165 pub mod default_trait_access;
166 pub mod derive;
167 pub mod doc;
168 pub mod double_comparison;
169 pub mod double_parens;
170 pub mod drop_bounds;
171 pub mod drop_forget_ref;
172 pub mod duration_subsec;
173 pub mod else_if_without_else;
174 pub mod empty_enum;
175 pub mod entry;
176 pub mod enum_clike;
177 pub mod enum_glob_use;
178 pub mod enum_variants;
179 pub mod eq_op;
180 pub mod erasing_op;
181 pub mod escape;
182 pub mod eta_reduction;
183 pub mod eval_order_dependence;
184 pub mod excessive_precision;
185 pub mod explicit_write;
186 pub mod fallible_impl_from;
187 pub mod format;
188 pub mod formatting;
189 pub mod functions;
190 pub mod get_last_with_len;
191 pub mod identity_conversion;
192 pub mod identity_op;
193 pub mod if_not_else;
194 pub mod implicit_return;
195 pub mod indexing_slicing;
196 pub mod infallible_destructuring_match;
197 pub mod infinite_iter;
198 pub mod inherent_impl;
199 pub mod inherent_to_string;
200 pub mod inline_fn_without_body;
201 pub mod int_plus_one;
202 pub mod integer_division;
203 pub mod items_after_statements;
204 pub mod large_enum_variant;
205 pub mod len_zero;
206 pub mod let_if_seq;
207 pub mod lifetimes;
208 pub mod literal_representation;
209 pub mod loops;
210 pub mod main_recursion;
211 pub mod map_clone;
212 pub mod map_unit_fn;
213 pub mod matches;
214 pub mod mem_discriminant;
215 pub mod mem_forget;
216 pub mod mem_replace;
217 pub mod methods;
218 pub mod minmax;
219 pub mod misc;
220 pub mod misc_early;
221 pub mod missing_const_for_fn;
222 pub mod missing_doc;
223 pub mod missing_inline;
224 pub mod multiple_crate_versions;
225 pub mod mut_mut;
226 pub mod mut_reference;
227 pub mod mutex_atomic;
228 pub mod needless_bool;
229 pub mod needless_borrow;
230 pub mod needless_borrowed_ref;
231 pub mod needless_continue;
232 pub mod needless_pass_by_value;
233 pub mod needless_update;
234 pub mod neg_cmp_op_on_partial_ord;
235 pub mod neg_multiply;
236 pub mod new_without_default;
237 pub mod no_effect;
238 pub mod non_copy_const;
239 pub mod non_expressive_names;
240 pub mod ok_if_let;
241 pub mod open_options;
242 pub mod overflow_check_conditional;
243 pub mod panic_unimplemented;
244 pub mod partialeq_ne_impl;
245 pub mod path_buf_push_overwrite;
246 pub mod precedence;
247 pub mod ptr;
248 pub mod ptr_offset_with_cast;
249 pub mod question_mark;
250 pub mod ranges;
251 pub mod redundant_clone;
252 pub mod redundant_field_names;
253 pub mod redundant_pattern_matching;
254 pub mod redundant_static_lifetimes;
255 pub mod reference;
256 pub mod regex;
257 pub mod replace_consts;
258 pub mod returns;
259 pub mod serde_api;
260 pub mod shadow;
261 pub mod slow_vector_initialization;
262 pub mod strings;
263 pub mod suspicious_trait_impl;
264 pub mod swap;
265 pub mod temporary_assignment;
266 pub mod trait_bounds;
267 pub mod transmute;
268 pub mod transmuting_null;
269 pub mod trivially_copy_pass_by_ref;
270 pub mod try_err;
271 pub mod types;
272 pub mod unicode;
273 pub mod unsafe_removed_from_name;
274 pub mod unused_io_amount;
275 pub mod unused_label;
276 pub mod unwrap;
277 pub mod use_self;
278 pub mod vec;
279 pub mod wildcard_dependencies;
280 pub mod write;
281 pub mod zero_div_zero;
282 // end lints modules, do not remove this comment, it’s used in `update_lints`
283
284 pub use crate::utils::conf::Conf;
285
286 mod reexport {
287     crate use syntax::ast::Name;
288 }
289
290 /// Register all pre expansion lints
291 ///
292 /// Pre-expansion lints run before any macro expansion has happened.
293 ///
294 /// Note that due to the architecture of the compiler, currently `cfg_attr` attributes on crate
295 /// level (i.e `#![cfg_attr(...)]`) will still be expanded even when using a pre-expansion pass.
296 ///
297 /// Used in `./src/driver.rs`.
298 pub fn register_pre_expansion_lints(
299     session: &rustc::session::Session,
300     store: &mut rustc::lint::LintStore,
301     conf: &Conf,
302 ) {
303     store.register_pre_expansion_pass(Some(session), true, false, box write::Write);
304     store.register_pre_expansion_pass(
305         Some(session),
306         true,
307         false,
308         box redundant_field_names::RedundantFieldNames,
309     );
310     store.register_pre_expansion_pass(
311         Some(session),
312         true,
313         false,
314         box non_expressive_names::NonExpressiveNames {
315             single_char_binding_names_threshold: conf.single_char_binding_names_threshold,
316         },
317     );
318     store.register_pre_expansion_pass(Some(session), true, false, box attrs::DeprecatedCfgAttribute);
319     store.register_pre_expansion_pass(Some(session), true, false, box dbg_macro::DbgMacro);
320 }
321
322 #[doc(hidden)]
323 pub fn read_conf(reg: &rustc_driver::plugin::Registry<'_>) -> Conf {
324     match utils::conf::file_from_args(reg.args()) {
325         Ok(file_name) => {
326             // if the user specified a file, it must exist, otherwise default to `clippy.toml` but
327             // do not require the file to exist
328             let file_name = if let Some(file_name) = file_name {
329                 Some(file_name)
330             } else {
331                 match utils::conf::lookup_conf_file() {
332                     Ok(path) => path,
333                     Err(error) => {
334                         reg.sess
335                             .struct_err(&format!("error finding Clippy's configuration file: {}", error))
336                             .emit();
337                         None
338                     },
339                 }
340             };
341
342             let file_name = file_name.map(|file_name| {
343                 if file_name.is_relative() {
344                     reg.sess
345                         .local_crate_source_file
346                         .as_ref()
347                         .and_then(|file| std::path::Path::new(&file).parent().map(std::path::Path::to_path_buf))
348                         .unwrap_or_default()
349                         .join(file_name)
350                 } else {
351                     file_name
352                 }
353             });
354
355             let (conf, errors) = utils::conf::read(file_name.as_ref().map(std::convert::AsRef::as_ref));
356
357             // all conf errors are non-fatal, we just use the default conf in case of error
358             for error in errors {
359                 reg.sess
360                     .struct_err(&format!(
361                         "error reading Clippy's configuration file `{}`: {}",
362                         file_name.as_ref().and_then(|p| p.to_str()).unwrap_or(""),
363                         error
364                     ))
365                     .emit();
366             }
367
368             conf
369         },
370         Err((err, span)) => {
371             reg.sess
372                 .struct_span_err(span, err)
373                 .span_note(span, "Clippy will use default configuration")
374                 .emit();
375             toml::from_str("").expect("we never error on empty config files")
376         },
377     }
378 }
379
380 /// Register all lints and lint groups with the rustc plugin registry
381 ///
382 /// Used in `./src/driver.rs`.
383 #[allow(clippy::too_many_lines)]
384 #[rustfmt::skip]
385 pub fn register_plugins(reg: &mut rustc_driver::plugin::Registry<'_>, conf: &Conf) {
386     let mut store = reg.sess.lint_store.borrow_mut();
387     register_removed_non_tool_lints(&mut store);
388
389     // begin deprecated lints, do not remove this comment, it’s used in `update_lints`
390     store.register_removed(
391         "clippy::should_assert_eq",
392         "`assert!()` will be more flexible with RFC 2011",
393     );
394     store.register_removed(
395         "clippy::extend_from_slice",
396         "`.extend_from_slice(_)` is a faster way to extend a Vec by a slice",
397     );
398     store.register_removed(
399         "clippy::range_step_by_zero",
400         "`iterator.step_by(0)` panics nowadays",
401     );
402     store.register_removed(
403         "clippy::unstable_as_slice",
404         "`Vec::as_slice` has been stabilized in 1.7",
405     );
406     store.register_removed(
407         "clippy::unstable_as_mut_slice",
408         "`Vec::as_mut_slice` has been stabilized in 1.7",
409     );
410     store.register_removed(
411         "clippy::str_to_string",
412         "using `str::to_string` is common even today and specialization will likely happen soon",
413     );
414     store.register_removed(
415         "clippy::string_to_string",
416         "using `string::to_string` is common even today and specialization will likely happen soon",
417     );
418     store.register_removed(
419         "clippy::misaligned_transmute",
420         "this lint has been split into cast_ptr_alignment and transmute_ptr_to_ptr",
421     );
422     store.register_removed(
423         "clippy::assign_ops",
424         "using compound assignment operators (e.g., `+=`) is harmless",
425     );
426     store.register_removed(
427         "clippy::if_let_redundant_pattern_matching",
428         "this lint has been changed to redundant_pattern_matching",
429     );
430     store.register_removed(
431         "clippy::unsafe_vector_initialization",
432         "the replacement suggested by this lint had substantially different behavior",
433     );
434     store.register_removed(
435         "clippy::invalid_ref",
436         "superseded by rustc lint `invalid_value`",
437     );
438     store.register_removed(
439         "clippy::unused_collect",
440         "`collect` has been marked as #[must_use] in rustc and that covers all cases of this lint",
441     );
442     // end deprecated lints, do not remove this comment, it’s used in `update_lints`
443
444     reg.register_late_lint_pass(box serde_api::SerdeAPI);
445     reg.register_early_lint_pass(box utils::internal_lints::ClippyLintsInternal);
446     reg.register_late_lint_pass(box utils::internal_lints::CompilerLintFunctions::new());
447     reg.register_late_lint_pass(box utils::internal_lints::LintWithoutLintPass::default());
448     reg.register_late_lint_pass(box utils::internal_lints::OuterExpnDataPass);
449     reg.register_late_lint_pass(box utils::inspector::DeepCodeInspector);
450     reg.register_late_lint_pass(box utils::author::Author);
451     reg.register_late_lint_pass(box types::Types);
452     reg.register_late_lint_pass(box booleans::NonminimalBool);
453     reg.register_late_lint_pass(box eq_op::EqOp);
454     reg.register_early_lint_pass(box enum_variants::EnumVariantNames::new(conf.enum_variant_name_threshold));
455     reg.register_late_lint_pass(box enum_glob_use::EnumGlobUse);
456     reg.register_late_lint_pass(box enum_clike::UnportableVariant);
457     reg.register_late_lint_pass(box excessive_precision::ExcessivePrecision);
458     reg.register_late_lint_pass(box bit_mask::BitMask::new(conf.verbose_bit_mask_threshold));
459     reg.register_late_lint_pass(box ptr::Ptr);
460     reg.register_late_lint_pass(box needless_bool::NeedlessBool);
461     reg.register_late_lint_pass(box needless_bool::BoolComparison);
462     reg.register_late_lint_pass(box approx_const::ApproxConstant);
463     reg.register_late_lint_pass(box misc::MiscLints);
464     reg.register_early_lint_pass(box precedence::Precedence);
465     reg.register_early_lint_pass(box needless_continue::NeedlessContinue);
466     reg.register_late_lint_pass(box eta_reduction::EtaReduction);
467     reg.register_late_lint_pass(box identity_op::IdentityOp);
468     reg.register_late_lint_pass(box erasing_op::ErasingOp);
469     reg.register_early_lint_pass(box items_after_statements::ItemsAfterStatements);
470     reg.register_late_lint_pass(box mut_mut::MutMut);
471     reg.register_late_lint_pass(box mut_reference::UnnecessaryMutPassed);
472     reg.register_late_lint_pass(box len_zero::LenZero);
473     reg.register_late_lint_pass(box attrs::Attributes);
474     reg.register_early_lint_pass(box collapsible_if::CollapsibleIf);
475     reg.register_late_lint_pass(box block_in_if_condition::BlockInIfCondition);
476     reg.register_late_lint_pass(box unicode::Unicode);
477     reg.register_late_lint_pass(box strings::StringAdd);
478     reg.register_early_lint_pass(box returns::Return);
479     reg.register_late_lint_pass(box implicit_return::ImplicitReturn);
480     reg.register_late_lint_pass(box methods::Methods);
481     reg.register_late_lint_pass(box map_clone::MapClone);
482     reg.register_late_lint_pass(box shadow::Shadow);
483     reg.register_late_lint_pass(box types::LetUnitValue);
484     reg.register_late_lint_pass(box types::UnitCmp);
485     reg.register_late_lint_pass(box loops::Loops);
486     reg.register_late_lint_pass(box main_recursion::MainRecursion::default());
487     reg.register_late_lint_pass(box lifetimes::Lifetimes);
488     reg.register_late_lint_pass(box entry::HashMapPass);
489     reg.register_late_lint_pass(box ranges::Ranges);
490     reg.register_late_lint_pass(box types::Casts);
491     reg.register_late_lint_pass(box types::TypeComplexity::new(conf.type_complexity_threshold));
492     reg.register_late_lint_pass(box matches::Matches);
493     reg.register_late_lint_pass(box minmax::MinMaxPass);
494     reg.register_late_lint_pass(box open_options::OpenOptions);
495     reg.register_late_lint_pass(box zero_div_zero::ZeroDiv);
496     reg.register_late_lint_pass(box mutex_atomic::Mutex);
497     reg.register_late_lint_pass(box needless_update::NeedlessUpdate);
498     reg.register_late_lint_pass(box needless_borrow::NeedlessBorrow::default());
499     reg.register_late_lint_pass(box needless_borrowed_ref::NeedlessBorrowedRef);
500     reg.register_late_lint_pass(box no_effect::NoEffect);
501     reg.register_late_lint_pass(box temporary_assignment::TemporaryAssignment);
502     reg.register_late_lint_pass(box transmute::Transmute);
503     reg.register_late_lint_pass(
504         box cognitive_complexity::CognitiveComplexity::new(conf.cognitive_complexity_threshold)
505     );
506     reg.register_late_lint_pass(box escape::BoxedLocal{too_large_for_stack: conf.too_large_for_stack});
507     reg.register_early_lint_pass(box misc_early::MiscEarlyLints);
508     reg.register_late_lint_pass(box panic_unimplemented::PanicUnimplemented);
509     reg.register_late_lint_pass(box strings::StringLitAsBytes);
510     reg.register_late_lint_pass(box derive::Derive);
511     reg.register_late_lint_pass(box types::CharLitAsU8);
512     reg.register_late_lint_pass(box vec::UselessVec);
513     reg.register_late_lint_pass(box drop_bounds::DropBounds);
514     reg.register_late_lint_pass(box get_last_with_len::GetLastWithLen);
515     reg.register_late_lint_pass(box drop_forget_ref::DropForgetRef);
516     reg.register_late_lint_pass(box empty_enum::EmptyEnum);
517     reg.register_late_lint_pass(box types::AbsurdExtremeComparisons);
518     reg.register_late_lint_pass(box types::InvalidUpcastComparisons);
519     reg.register_late_lint_pass(box regex::Regex::default());
520     reg.register_late_lint_pass(box copies::CopyAndPaste);
521     reg.register_late_lint_pass(box copy_iterator::CopyIterator);
522     reg.register_late_lint_pass(box format::UselessFormat);
523     reg.register_early_lint_pass(box formatting::Formatting);
524     reg.register_late_lint_pass(box swap::Swap);
525     reg.register_early_lint_pass(box if_not_else::IfNotElse);
526     reg.register_early_lint_pass(box else_if_without_else::ElseIfWithoutElse);
527     reg.register_early_lint_pass(box int_plus_one::IntPlusOne);
528     reg.register_late_lint_pass(box overflow_check_conditional::OverflowCheckConditional);
529     reg.register_late_lint_pass(box unused_label::UnusedLabel);
530     reg.register_late_lint_pass(box new_without_default::NewWithoutDefault::default());
531     reg.register_late_lint_pass(box blacklisted_name::BlacklistedName::new(
532             conf.blacklisted_names.iter().cloned().collect()
533     ));
534     reg.register_late_lint_pass(box functions::Functions::new(conf.too_many_arguments_threshold, conf.too_many_lines_threshold));
535     reg.register_early_lint_pass(box doc::DocMarkdown::new(conf.doc_valid_idents.iter().cloned().collect()));
536     reg.register_late_lint_pass(box neg_multiply::NegMultiply);
537     reg.register_early_lint_pass(box unsafe_removed_from_name::UnsafeNameRemoval);
538     reg.register_late_lint_pass(box mem_discriminant::MemDiscriminant);
539     reg.register_late_lint_pass(box mem_forget::MemForget);
540     reg.register_late_lint_pass(box mem_replace::MemReplace);
541     reg.register_late_lint_pass(box arithmetic::Arithmetic::default());
542     reg.register_late_lint_pass(box assign_ops::AssignOps);
543     reg.register_late_lint_pass(box let_if_seq::LetIfSeq);
544     reg.register_late_lint_pass(box eval_order_dependence::EvalOrderDependence);
545     reg.register_late_lint_pass(box missing_doc::MissingDoc::new());
546     reg.register_late_lint_pass(box missing_inline::MissingInline);
547     reg.register_late_lint_pass(box ok_if_let::OkIfLet);
548     reg.register_late_lint_pass(box redundant_pattern_matching::RedundantPatternMatching);
549     reg.register_late_lint_pass(box partialeq_ne_impl::PartialEqNeImpl);
550     reg.register_early_lint_pass(box reference::DerefAddrOf);
551     reg.register_early_lint_pass(box reference::RefInDeref);
552     reg.register_early_lint_pass(box double_parens::DoubleParens);
553     reg.register_late_lint_pass(box unused_io_amount::UnusedIoAmount);
554     reg.register_late_lint_pass(box large_enum_variant::LargeEnumVariant::new(conf.enum_variant_size_threshold));
555     reg.register_late_lint_pass(box explicit_write::ExplicitWrite);
556     reg.register_late_lint_pass(box needless_pass_by_value::NeedlessPassByValue);
557     reg.register_late_lint_pass(box trivially_copy_pass_by_ref::TriviallyCopyPassByRef::new(
558             conf.trivial_copy_size_limit,
559             &reg.sess.target,
560     ));
561     reg.register_early_lint_pass(box literal_representation::LiteralDigitGrouping);
562     reg.register_early_lint_pass(box literal_representation::DecimalLiteralRepresentation::new(
563             conf.literal_representation_threshold
564     ));
565     reg.register_late_lint_pass(box try_err::TryErr);
566     reg.register_late_lint_pass(box use_self::UseSelf);
567     reg.register_late_lint_pass(box bytecount::ByteCount);
568     reg.register_late_lint_pass(box infinite_iter::InfiniteIter);
569     reg.register_late_lint_pass(box inline_fn_without_body::InlineFnWithoutBody);
570     reg.register_late_lint_pass(box identity_conversion::IdentityConversion::default());
571     reg.register_late_lint_pass(box types::ImplicitHasher);
572     reg.register_early_lint_pass(box redundant_static_lifetimes::RedundantStaticLifetimes);
573     reg.register_late_lint_pass(box fallible_impl_from::FallibleImplFrom);
574     reg.register_late_lint_pass(box replace_consts::ReplaceConsts);
575     reg.register_late_lint_pass(box types::UnitArg);
576     reg.register_late_lint_pass(box double_comparison::DoubleComparisons);
577     reg.register_late_lint_pass(box question_mark::QuestionMark);
578     reg.register_late_lint_pass(box suspicious_trait_impl::SuspiciousImpl);
579     reg.register_early_lint_pass(box cargo_common_metadata::CargoCommonMetadata);
580     reg.register_early_lint_pass(box multiple_crate_versions::MultipleCrateVersions);
581     reg.register_early_lint_pass(box wildcard_dependencies::WildcardDependencies);
582     reg.register_late_lint_pass(box map_unit_fn::MapUnit);
583     reg.register_late_lint_pass(box infallible_destructuring_match::InfallibleDestructingMatch);
584     reg.register_late_lint_pass(box inherent_impl::MultipleInherentImpl::default());
585     reg.register_late_lint_pass(box neg_cmp_op_on_partial_ord::NoNegCompOpForPartialOrd);
586     reg.register_late_lint_pass(box unwrap::Unwrap);
587     reg.register_late_lint_pass(box duration_subsec::DurationSubsec);
588     reg.register_late_lint_pass(box default_trait_access::DefaultTraitAccess);
589     reg.register_late_lint_pass(box indexing_slicing::IndexingSlicing);
590     reg.register_late_lint_pass(box non_copy_const::NonCopyConst);
591     reg.register_late_lint_pass(box ptr_offset_with_cast::PtrOffsetWithCast);
592     reg.register_late_lint_pass(box redundant_clone::RedundantClone);
593     reg.register_late_lint_pass(box slow_vector_initialization::SlowVectorInit);
594     reg.register_late_lint_pass(box types::RefToMut);
595     reg.register_late_lint_pass(box assertions_on_constants::AssertionsOnConstants);
596     reg.register_late_lint_pass(box missing_const_for_fn::MissingConstForFn);
597     reg.register_late_lint_pass(box transmuting_null::TransmutingNull);
598     reg.register_late_lint_pass(box path_buf_push_overwrite::PathBufPushOverwrite);
599     reg.register_late_lint_pass(box checked_conversions::CheckedConversions);
600     reg.register_late_lint_pass(box integer_division::IntegerDivision);
601     reg.register_late_lint_pass(box inherent_to_string::InherentToString);
602     reg.register_late_lint_pass(box trait_bounds::TraitBounds);
603
604     reg.register_lint_group("clippy::restriction", Some("clippy_restriction"), vec![
605         arithmetic::FLOAT_ARITHMETIC,
606         arithmetic::INTEGER_ARITHMETIC,
607         dbg_macro::DBG_MACRO,
608         else_if_without_else::ELSE_IF_WITHOUT_ELSE,
609         implicit_return::IMPLICIT_RETURN,
610         indexing_slicing::INDEXING_SLICING,
611         inherent_impl::MULTIPLE_INHERENT_IMPL,
612         integer_division::INTEGER_DIVISION,
613         literal_representation::DECIMAL_LITERAL_REPRESENTATION,
614         matches::WILDCARD_ENUM_MATCH_ARM,
615         mem_forget::MEM_FORGET,
616         methods::CLONE_ON_REF_PTR,
617         methods::GET_UNWRAP,
618         methods::OPTION_UNWRAP_USED,
619         methods::RESULT_UNWRAP_USED,
620         methods::WRONG_PUB_SELF_CONVENTION,
621         misc::FLOAT_CMP_CONST,
622         missing_doc::MISSING_DOCS_IN_PRIVATE_ITEMS,
623         missing_inline::MISSING_INLINE_IN_PUBLIC_ITEMS,
624         panic_unimplemented::UNIMPLEMENTED,
625         shadow::SHADOW_REUSE,
626         shadow::SHADOW_SAME,
627         strings::STRING_ADD,
628         write::PRINT_STDOUT,
629         write::USE_DEBUG,
630     ]);
631
632     reg.register_lint_group("clippy::pedantic", Some("clippy_pedantic"), vec![
633         attrs::INLINE_ALWAYS,
634         checked_conversions::CHECKED_CONVERSIONS,
635         copies::MATCH_SAME_ARMS,
636         copy_iterator::COPY_ITERATOR,
637         default_trait_access::DEFAULT_TRAIT_ACCESS,
638         derive::EXPL_IMPL_CLONE_ON_COPY,
639         doc::DOC_MARKDOWN,
640         empty_enum::EMPTY_ENUM,
641         enum_glob_use::ENUM_GLOB_USE,
642         enum_variants::MODULE_NAME_REPETITIONS,
643         enum_variants::PUB_ENUM_VARIANT_NAMES,
644         eta_reduction::REDUNDANT_CLOSURE_FOR_METHOD_CALLS,
645         functions::TOO_MANY_LINES,
646         if_not_else::IF_NOT_ELSE,
647         infinite_iter::MAYBE_INFINITE_ITER,
648         items_after_statements::ITEMS_AFTER_STATEMENTS,
649         literal_representation::LARGE_DIGIT_GROUPS,
650         loops::EXPLICIT_INTO_ITER_LOOP,
651         loops::EXPLICIT_ITER_LOOP,
652         matches::SINGLE_MATCH_ELSE,
653         methods::FILTER_MAP,
654         methods::FILTER_MAP_NEXT,
655         methods::FIND_MAP,
656         methods::MAP_FLATTEN,
657         methods::OPTION_MAP_UNWRAP_OR,
658         methods::OPTION_MAP_UNWRAP_OR_ELSE,
659         methods::RESULT_MAP_UNWRAP_OR_ELSE,
660         misc::USED_UNDERSCORE_BINDING,
661         misc_early::UNSEPARATED_LITERAL_SUFFIX,
662         mut_mut::MUT_MUT,
663         needless_continue::NEEDLESS_CONTINUE,
664         needless_pass_by_value::NEEDLESS_PASS_BY_VALUE,
665         non_expressive_names::SIMILAR_NAMES,
666         replace_consts::REPLACE_CONSTS,
667         shadow::SHADOW_UNRELATED,
668         strings::STRING_ADD_ASSIGN,
669         trait_bounds::TYPE_REPETITION_IN_BOUNDS,
670         types::CAST_POSSIBLE_TRUNCATION,
671         types::CAST_POSSIBLE_WRAP,
672         types::CAST_PRECISION_LOSS,
673         types::CAST_SIGN_LOSS,
674         types::INVALID_UPCAST_COMPARISONS,
675         types::LINKEDLIST,
676         unicode::NON_ASCII_LITERAL,
677         unicode::UNICODE_NOT_NFC,
678         use_self::USE_SELF,
679     ]);
680
681     reg.register_lint_group("clippy::internal", Some("clippy_internal"), vec![
682         utils::internal_lints::CLIPPY_LINTS_INTERNAL,
683         utils::internal_lints::COMPILER_LINT_FUNCTIONS,
684         utils::internal_lints::LINT_WITHOUT_LINT_PASS,
685         utils::internal_lints::OUTER_EXPN_EXPN_DATA,
686     ]);
687
688     reg.register_lint_group("clippy::all", Some("clippy"), vec![
689         approx_const::APPROX_CONSTANT,
690         assertions_on_constants::ASSERTIONS_ON_CONSTANTS,
691         assign_ops::ASSIGN_OP_PATTERN,
692         assign_ops::MISREFACTORED_ASSIGN_OP,
693         attrs::DEPRECATED_CFG_ATTR,
694         attrs::DEPRECATED_SEMVER,
695         attrs::UNKNOWN_CLIPPY_LINTS,
696         attrs::USELESS_ATTRIBUTE,
697         bit_mask::BAD_BIT_MASK,
698         bit_mask::INEFFECTIVE_BIT_MASK,
699         bit_mask::VERBOSE_BIT_MASK,
700         blacklisted_name::BLACKLISTED_NAME,
701         block_in_if_condition::BLOCK_IN_IF_CONDITION_EXPR,
702         block_in_if_condition::BLOCK_IN_IF_CONDITION_STMT,
703         booleans::LOGIC_BUG,
704         booleans::NONMINIMAL_BOOL,
705         bytecount::NAIVE_BYTECOUNT,
706         cognitive_complexity::COGNITIVE_COMPLEXITY,
707         collapsible_if::COLLAPSIBLE_IF,
708         copies::IFS_SAME_COND,
709         copies::IF_SAME_THEN_ELSE,
710         derive::DERIVE_HASH_XOR_EQ,
711         double_comparison::DOUBLE_COMPARISONS,
712         double_parens::DOUBLE_PARENS,
713         drop_bounds::DROP_BOUNDS,
714         drop_forget_ref::DROP_COPY,
715         drop_forget_ref::DROP_REF,
716         drop_forget_ref::FORGET_COPY,
717         drop_forget_ref::FORGET_REF,
718         duration_subsec::DURATION_SUBSEC,
719         entry::MAP_ENTRY,
720         enum_clike::ENUM_CLIKE_UNPORTABLE_VARIANT,
721         enum_variants::ENUM_VARIANT_NAMES,
722         enum_variants::MODULE_INCEPTION,
723         eq_op::EQ_OP,
724         eq_op::OP_REF,
725         erasing_op::ERASING_OP,
726         escape::BOXED_LOCAL,
727         eta_reduction::REDUNDANT_CLOSURE,
728         eval_order_dependence::DIVERGING_SUB_EXPRESSION,
729         eval_order_dependence::EVAL_ORDER_DEPENDENCE,
730         excessive_precision::EXCESSIVE_PRECISION,
731         explicit_write::EXPLICIT_WRITE,
732         format::USELESS_FORMAT,
733         formatting::POSSIBLE_MISSING_COMMA,
734         formatting::SUSPICIOUS_ASSIGNMENT_FORMATTING,
735         formatting::SUSPICIOUS_ELSE_FORMATTING,
736         functions::NOT_UNSAFE_PTR_ARG_DEREF,
737         functions::TOO_MANY_ARGUMENTS,
738         get_last_with_len::GET_LAST_WITH_LEN,
739         identity_conversion::IDENTITY_CONVERSION,
740         identity_op::IDENTITY_OP,
741         indexing_slicing::OUT_OF_BOUNDS_INDEXING,
742         infallible_destructuring_match::INFALLIBLE_DESTRUCTURING_MATCH,
743         infinite_iter::INFINITE_ITER,
744         inherent_to_string::INHERENT_TO_STRING,
745         inherent_to_string::INHERENT_TO_STRING_SHADOW_DISPLAY,
746         inline_fn_without_body::INLINE_FN_WITHOUT_BODY,
747         int_plus_one::INT_PLUS_ONE,
748         large_enum_variant::LARGE_ENUM_VARIANT,
749         len_zero::LEN_WITHOUT_IS_EMPTY,
750         len_zero::LEN_ZERO,
751         let_if_seq::USELESS_LET_IF_SEQ,
752         lifetimes::EXTRA_UNUSED_LIFETIMES,
753         lifetimes::NEEDLESS_LIFETIMES,
754         literal_representation::INCONSISTENT_DIGIT_GROUPING,
755         literal_representation::MISTYPED_LITERAL_SUFFIXES,
756         literal_representation::UNREADABLE_LITERAL,
757         loops::EMPTY_LOOP,
758         loops::EXPLICIT_COUNTER_LOOP,
759         loops::FOR_KV_MAP,
760         loops::FOR_LOOP_OVER_OPTION,
761         loops::FOR_LOOP_OVER_RESULT,
762         loops::ITER_NEXT_LOOP,
763         loops::MANUAL_MEMCPY,
764         loops::MUT_RANGE_BOUND,
765         loops::NEEDLESS_COLLECT,
766         loops::NEEDLESS_RANGE_LOOP,
767         loops::NEVER_LOOP,
768         loops::REVERSE_RANGE_LOOP,
769         loops::WHILE_IMMUTABLE_CONDITION,
770         loops::WHILE_LET_LOOP,
771         loops::WHILE_LET_ON_ITERATOR,
772         main_recursion::MAIN_RECURSION,
773         map_clone::MAP_CLONE,
774         map_unit_fn::OPTION_MAP_UNIT_FN,
775         map_unit_fn::RESULT_MAP_UNIT_FN,
776         matches::MATCH_AS_REF,
777         matches::MATCH_BOOL,
778         matches::MATCH_OVERLAPPING_ARM,
779         matches::MATCH_REF_PATS,
780         matches::MATCH_WILD_ERR_ARM,
781         matches::SINGLE_MATCH,
782         mem_discriminant::MEM_DISCRIMINANT_NON_ENUM,
783         mem_replace::MEM_REPLACE_OPTION_WITH_NONE,
784         methods::CHARS_LAST_CMP,
785         methods::CHARS_NEXT_CMP,
786         methods::CLONE_DOUBLE_REF,
787         methods::CLONE_ON_COPY,
788         methods::EXPECT_FUN_CALL,
789         methods::FILTER_NEXT,
790         methods::FLAT_MAP_IDENTITY,
791         methods::INTO_ITER_ON_ARRAY,
792         methods::INTO_ITER_ON_REF,
793         methods::ITER_CLONED_COLLECT,
794         methods::ITER_NTH,
795         methods::ITER_SKIP_NEXT,
796         methods::NEW_RET_NO_SELF,
797         methods::OK_EXPECT,
798         methods::OPTION_AND_THEN_SOME,
799         methods::OPTION_MAP_OR_NONE,
800         methods::OR_FUN_CALL,
801         methods::SEARCH_IS_SOME,
802         methods::SHOULD_IMPLEMENT_TRAIT,
803         methods::SINGLE_CHAR_PATTERN,
804         methods::STRING_EXTEND_CHARS,
805         methods::SUSPICIOUS_MAP,
806         methods::TEMPORARY_CSTRING_AS_PTR,
807         methods::UNNECESSARY_FILTER_MAP,
808         methods::UNNECESSARY_FOLD,
809         methods::USELESS_ASREF,
810         methods::WRONG_SELF_CONVENTION,
811         minmax::MIN_MAX,
812         misc::CMP_NAN,
813         misc::CMP_OWNED,
814         misc::FLOAT_CMP,
815         misc::MODULO_ONE,
816         misc::REDUNDANT_PATTERN,
817         misc::SHORT_CIRCUIT_STATEMENT,
818         misc::TOPLEVEL_REF_ARG,
819         misc::ZERO_PTR,
820         misc_early::BUILTIN_TYPE_SHADOW,
821         misc_early::DOUBLE_NEG,
822         misc_early::DUPLICATE_UNDERSCORE_ARGUMENT,
823         misc_early::MIXED_CASE_HEX_LITERALS,
824         misc_early::REDUNDANT_CLOSURE_CALL,
825         misc_early::UNNEEDED_FIELD_PATTERN,
826         misc_early::ZERO_PREFIXED_LITERAL,
827         mut_reference::UNNECESSARY_MUT_PASSED,
828         mutex_atomic::MUTEX_ATOMIC,
829         needless_bool::BOOL_COMPARISON,
830         needless_bool::NEEDLESS_BOOL,
831         needless_borrowed_ref::NEEDLESS_BORROWED_REFERENCE,
832         needless_update::NEEDLESS_UPDATE,
833         neg_cmp_op_on_partial_ord::NEG_CMP_OP_ON_PARTIAL_ORD,
834         neg_multiply::NEG_MULTIPLY,
835         new_without_default::NEW_WITHOUT_DEFAULT,
836         no_effect::NO_EFFECT,
837         no_effect::UNNECESSARY_OPERATION,
838         non_copy_const::BORROW_INTERIOR_MUTABLE_CONST,
839         non_copy_const::DECLARE_INTERIOR_MUTABLE_CONST,
840         non_expressive_names::JUST_UNDERSCORES_AND_DIGITS,
841         non_expressive_names::MANY_SINGLE_CHAR_NAMES,
842         ok_if_let::IF_LET_SOME_RESULT,
843         open_options::NONSENSICAL_OPEN_OPTIONS,
844         overflow_check_conditional::OVERFLOW_CHECK_CONDITIONAL,
845         panic_unimplemented::PANIC_PARAMS,
846         partialeq_ne_impl::PARTIALEQ_NE_IMPL,
847         precedence::PRECEDENCE,
848         ptr::CMP_NULL,
849         ptr::MUT_FROM_REF,
850         ptr::PTR_ARG,
851         ptr_offset_with_cast::PTR_OFFSET_WITH_CAST,
852         question_mark::QUESTION_MARK,
853         ranges::ITERATOR_STEP_BY_ZERO,
854         ranges::RANGE_MINUS_ONE,
855         ranges::RANGE_PLUS_ONE,
856         ranges::RANGE_ZIP_WITH_LEN,
857         redundant_field_names::REDUNDANT_FIELD_NAMES,
858         redundant_pattern_matching::REDUNDANT_PATTERN_MATCHING,
859         redundant_static_lifetimes::REDUNDANT_STATIC_LIFETIMES,
860         reference::DEREF_ADDROF,
861         reference::REF_IN_DEREF,
862         regex::INVALID_REGEX,
863         regex::REGEX_MACRO,
864         regex::TRIVIAL_REGEX,
865         returns::LET_AND_RETURN,
866         returns::NEEDLESS_RETURN,
867         returns::UNUSED_UNIT,
868         serde_api::SERDE_API_MISUSE,
869         slow_vector_initialization::SLOW_VECTOR_INITIALIZATION,
870         strings::STRING_LIT_AS_BYTES,
871         suspicious_trait_impl::SUSPICIOUS_ARITHMETIC_IMPL,
872         suspicious_trait_impl::SUSPICIOUS_OP_ASSIGN_IMPL,
873         swap::ALMOST_SWAPPED,
874         swap::MANUAL_SWAP,
875         temporary_assignment::TEMPORARY_ASSIGNMENT,
876         transmute::CROSSPOINTER_TRANSMUTE,
877         transmute::TRANSMUTE_BYTES_TO_STR,
878         transmute::TRANSMUTE_INT_TO_BOOL,
879         transmute::TRANSMUTE_INT_TO_CHAR,
880         transmute::TRANSMUTE_INT_TO_FLOAT,
881         transmute::TRANSMUTE_PTR_TO_PTR,
882         transmute::TRANSMUTE_PTR_TO_REF,
883         transmute::USELESS_TRANSMUTE,
884         transmute::WRONG_TRANSMUTE,
885         transmuting_null::TRANSMUTING_NULL,
886         trivially_copy_pass_by_ref::TRIVIALLY_COPY_PASS_BY_REF,
887         try_err::TRY_ERR,
888         types::ABSURD_EXTREME_COMPARISONS,
889         types::BORROWED_BOX,
890         types::BOX_VEC,
891         types::CAST_LOSSLESS,
892         types::CAST_PTR_ALIGNMENT,
893         types::CAST_REF_TO_MUT,
894         types::CHAR_LIT_AS_U8,
895         types::FN_TO_NUMERIC_CAST,
896         types::FN_TO_NUMERIC_CAST_WITH_TRUNCATION,
897         types::IMPLICIT_HASHER,
898         types::LET_UNIT_VALUE,
899         types::OPTION_OPTION,
900         types::TYPE_COMPLEXITY,
901         types::UNIT_ARG,
902         types::UNIT_CMP,
903         types::UNNECESSARY_CAST,
904         types::VEC_BOX,
905         unicode::ZERO_WIDTH_SPACE,
906         unsafe_removed_from_name::UNSAFE_REMOVED_FROM_NAME,
907         unused_io_amount::UNUSED_IO_AMOUNT,
908         unused_label::UNUSED_LABEL,
909         unwrap::PANICKING_UNWRAP,
910         unwrap::UNNECESSARY_UNWRAP,
911         vec::USELESS_VEC,
912         write::PRINTLN_EMPTY_STRING,
913         write::PRINT_LITERAL,
914         write::PRINT_WITH_NEWLINE,
915         write::WRITELN_EMPTY_STRING,
916         write::WRITE_LITERAL,
917         write::WRITE_WITH_NEWLINE,
918         zero_div_zero::ZERO_DIVIDED_BY_ZERO,
919     ]);
920
921     reg.register_lint_group("clippy::style", Some("clippy_style"), vec![
922         assertions_on_constants::ASSERTIONS_ON_CONSTANTS,
923         assign_ops::ASSIGN_OP_PATTERN,
924         attrs::UNKNOWN_CLIPPY_LINTS,
925         bit_mask::VERBOSE_BIT_MASK,
926         blacklisted_name::BLACKLISTED_NAME,
927         block_in_if_condition::BLOCK_IN_IF_CONDITION_EXPR,
928         block_in_if_condition::BLOCK_IN_IF_CONDITION_STMT,
929         collapsible_if::COLLAPSIBLE_IF,
930         enum_variants::ENUM_VARIANT_NAMES,
931         enum_variants::MODULE_INCEPTION,
932         eq_op::OP_REF,
933         eta_reduction::REDUNDANT_CLOSURE,
934         excessive_precision::EXCESSIVE_PRECISION,
935         formatting::SUSPICIOUS_ASSIGNMENT_FORMATTING,
936         formatting::SUSPICIOUS_ELSE_FORMATTING,
937         infallible_destructuring_match::INFALLIBLE_DESTRUCTURING_MATCH,
938         inherent_to_string::INHERENT_TO_STRING,
939         len_zero::LEN_WITHOUT_IS_EMPTY,
940         len_zero::LEN_ZERO,
941         let_if_seq::USELESS_LET_IF_SEQ,
942         literal_representation::INCONSISTENT_DIGIT_GROUPING,
943         literal_representation::UNREADABLE_LITERAL,
944         loops::EMPTY_LOOP,
945         loops::FOR_KV_MAP,
946         loops::NEEDLESS_RANGE_LOOP,
947         loops::WHILE_LET_ON_ITERATOR,
948         main_recursion::MAIN_RECURSION,
949         map_clone::MAP_CLONE,
950         matches::MATCH_BOOL,
951         matches::MATCH_OVERLAPPING_ARM,
952         matches::MATCH_REF_PATS,
953         matches::MATCH_WILD_ERR_ARM,
954         matches::SINGLE_MATCH,
955         mem_replace::MEM_REPLACE_OPTION_WITH_NONE,
956         methods::CHARS_LAST_CMP,
957         methods::INTO_ITER_ON_REF,
958         methods::ITER_CLONED_COLLECT,
959         methods::ITER_SKIP_NEXT,
960         methods::NEW_RET_NO_SELF,
961         methods::OK_EXPECT,
962         methods::OPTION_MAP_OR_NONE,
963         methods::SHOULD_IMPLEMENT_TRAIT,
964         methods::STRING_EXTEND_CHARS,
965         methods::UNNECESSARY_FOLD,
966         methods::WRONG_SELF_CONVENTION,
967         misc::REDUNDANT_PATTERN,
968         misc::TOPLEVEL_REF_ARG,
969         misc::ZERO_PTR,
970         misc_early::BUILTIN_TYPE_SHADOW,
971         misc_early::DOUBLE_NEG,
972         misc_early::DUPLICATE_UNDERSCORE_ARGUMENT,
973         misc_early::MIXED_CASE_HEX_LITERALS,
974         misc_early::UNNEEDED_FIELD_PATTERN,
975         mut_reference::UNNECESSARY_MUT_PASSED,
976         neg_multiply::NEG_MULTIPLY,
977         new_without_default::NEW_WITHOUT_DEFAULT,
978         non_expressive_names::JUST_UNDERSCORES_AND_DIGITS,
979         non_expressive_names::MANY_SINGLE_CHAR_NAMES,
980         ok_if_let::IF_LET_SOME_RESULT,
981         panic_unimplemented::PANIC_PARAMS,
982         ptr::CMP_NULL,
983         ptr::PTR_ARG,
984         question_mark::QUESTION_MARK,
985         redundant_field_names::REDUNDANT_FIELD_NAMES,
986         redundant_pattern_matching::REDUNDANT_PATTERN_MATCHING,
987         redundant_static_lifetimes::REDUNDANT_STATIC_LIFETIMES,
988         regex::REGEX_MACRO,
989         regex::TRIVIAL_REGEX,
990         returns::LET_AND_RETURN,
991         returns::NEEDLESS_RETURN,
992         returns::UNUSED_UNIT,
993         strings::STRING_LIT_AS_BYTES,
994         try_err::TRY_ERR,
995         types::FN_TO_NUMERIC_CAST,
996         types::FN_TO_NUMERIC_CAST_WITH_TRUNCATION,
997         types::IMPLICIT_HASHER,
998         types::LET_UNIT_VALUE,
999         unsafe_removed_from_name::UNSAFE_REMOVED_FROM_NAME,
1000         write::PRINTLN_EMPTY_STRING,
1001         write::PRINT_LITERAL,
1002         write::PRINT_WITH_NEWLINE,
1003         write::WRITELN_EMPTY_STRING,
1004         write::WRITE_LITERAL,
1005         write::WRITE_WITH_NEWLINE,
1006     ]);
1007
1008     reg.register_lint_group("clippy::complexity", Some("clippy_complexity"), vec![
1009         assign_ops::MISREFACTORED_ASSIGN_OP,
1010         attrs::DEPRECATED_CFG_ATTR,
1011         booleans::NONMINIMAL_BOOL,
1012         cognitive_complexity::COGNITIVE_COMPLEXITY,
1013         double_comparison::DOUBLE_COMPARISONS,
1014         double_parens::DOUBLE_PARENS,
1015         duration_subsec::DURATION_SUBSEC,
1016         eval_order_dependence::DIVERGING_SUB_EXPRESSION,
1017         eval_order_dependence::EVAL_ORDER_DEPENDENCE,
1018         explicit_write::EXPLICIT_WRITE,
1019         format::USELESS_FORMAT,
1020         functions::TOO_MANY_ARGUMENTS,
1021         get_last_with_len::GET_LAST_WITH_LEN,
1022         identity_conversion::IDENTITY_CONVERSION,
1023         identity_op::IDENTITY_OP,
1024         int_plus_one::INT_PLUS_ONE,
1025         lifetimes::EXTRA_UNUSED_LIFETIMES,
1026         lifetimes::NEEDLESS_LIFETIMES,
1027         loops::EXPLICIT_COUNTER_LOOP,
1028         loops::MUT_RANGE_BOUND,
1029         loops::WHILE_LET_LOOP,
1030         map_unit_fn::OPTION_MAP_UNIT_FN,
1031         map_unit_fn::RESULT_MAP_UNIT_FN,
1032         matches::MATCH_AS_REF,
1033         methods::CHARS_NEXT_CMP,
1034         methods::CLONE_ON_COPY,
1035         methods::FILTER_NEXT,
1036         methods::FLAT_MAP_IDENTITY,
1037         methods::OPTION_AND_THEN_SOME,
1038         methods::SEARCH_IS_SOME,
1039         methods::SUSPICIOUS_MAP,
1040         methods::UNNECESSARY_FILTER_MAP,
1041         methods::USELESS_ASREF,
1042         misc::SHORT_CIRCUIT_STATEMENT,
1043         misc_early::REDUNDANT_CLOSURE_CALL,
1044         misc_early::ZERO_PREFIXED_LITERAL,
1045         needless_bool::BOOL_COMPARISON,
1046         needless_bool::NEEDLESS_BOOL,
1047         needless_borrowed_ref::NEEDLESS_BORROWED_REFERENCE,
1048         needless_update::NEEDLESS_UPDATE,
1049         neg_cmp_op_on_partial_ord::NEG_CMP_OP_ON_PARTIAL_ORD,
1050         no_effect::NO_EFFECT,
1051         no_effect::UNNECESSARY_OPERATION,
1052         overflow_check_conditional::OVERFLOW_CHECK_CONDITIONAL,
1053         partialeq_ne_impl::PARTIALEQ_NE_IMPL,
1054         precedence::PRECEDENCE,
1055         ptr_offset_with_cast::PTR_OFFSET_WITH_CAST,
1056         ranges::RANGE_MINUS_ONE,
1057         ranges::RANGE_PLUS_ONE,
1058         ranges::RANGE_ZIP_WITH_LEN,
1059         reference::DEREF_ADDROF,
1060         reference::REF_IN_DEREF,
1061         swap::MANUAL_SWAP,
1062         temporary_assignment::TEMPORARY_ASSIGNMENT,
1063         transmute::CROSSPOINTER_TRANSMUTE,
1064         transmute::TRANSMUTE_BYTES_TO_STR,
1065         transmute::TRANSMUTE_INT_TO_BOOL,
1066         transmute::TRANSMUTE_INT_TO_CHAR,
1067         transmute::TRANSMUTE_INT_TO_FLOAT,
1068         transmute::TRANSMUTE_PTR_TO_PTR,
1069         transmute::TRANSMUTE_PTR_TO_REF,
1070         transmute::USELESS_TRANSMUTE,
1071         types::BORROWED_BOX,
1072         types::CAST_LOSSLESS,
1073         types::CHAR_LIT_AS_U8,
1074         types::OPTION_OPTION,
1075         types::TYPE_COMPLEXITY,
1076         types::UNIT_ARG,
1077         types::UNNECESSARY_CAST,
1078         types::VEC_BOX,
1079         unused_label::UNUSED_LABEL,
1080         unwrap::UNNECESSARY_UNWRAP,
1081         zero_div_zero::ZERO_DIVIDED_BY_ZERO,
1082     ]);
1083
1084     reg.register_lint_group("clippy::correctness", Some("clippy_correctness"), vec![
1085         approx_const::APPROX_CONSTANT,
1086         attrs::DEPRECATED_SEMVER,
1087         attrs::USELESS_ATTRIBUTE,
1088         bit_mask::BAD_BIT_MASK,
1089         bit_mask::INEFFECTIVE_BIT_MASK,
1090         booleans::LOGIC_BUG,
1091         copies::IFS_SAME_COND,
1092         copies::IF_SAME_THEN_ELSE,
1093         derive::DERIVE_HASH_XOR_EQ,
1094         drop_bounds::DROP_BOUNDS,
1095         drop_forget_ref::DROP_COPY,
1096         drop_forget_ref::DROP_REF,
1097         drop_forget_ref::FORGET_COPY,
1098         drop_forget_ref::FORGET_REF,
1099         enum_clike::ENUM_CLIKE_UNPORTABLE_VARIANT,
1100         eq_op::EQ_OP,
1101         erasing_op::ERASING_OP,
1102         formatting::POSSIBLE_MISSING_COMMA,
1103         functions::NOT_UNSAFE_PTR_ARG_DEREF,
1104         indexing_slicing::OUT_OF_BOUNDS_INDEXING,
1105         infinite_iter::INFINITE_ITER,
1106         inherent_to_string::INHERENT_TO_STRING_SHADOW_DISPLAY,
1107         inline_fn_without_body::INLINE_FN_WITHOUT_BODY,
1108         literal_representation::MISTYPED_LITERAL_SUFFIXES,
1109         loops::FOR_LOOP_OVER_OPTION,
1110         loops::FOR_LOOP_OVER_RESULT,
1111         loops::ITER_NEXT_LOOP,
1112         loops::NEVER_LOOP,
1113         loops::REVERSE_RANGE_LOOP,
1114         loops::WHILE_IMMUTABLE_CONDITION,
1115         mem_discriminant::MEM_DISCRIMINANT_NON_ENUM,
1116         methods::CLONE_DOUBLE_REF,
1117         methods::INTO_ITER_ON_ARRAY,
1118         methods::TEMPORARY_CSTRING_AS_PTR,
1119         minmax::MIN_MAX,
1120         misc::CMP_NAN,
1121         misc::FLOAT_CMP,
1122         misc::MODULO_ONE,
1123         non_copy_const::BORROW_INTERIOR_MUTABLE_CONST,
1124         non_copy_const::DECLARE_INTERIOR_MUTABLE_CONST,
1125         open_options::NONSENSICAL_OPEN_OPTIONS,
1126         ptr::MUT_FROM_REF,
1127         ranges::ITERATOR_STEP_BY_ZERO,
1128         regex::INVALID_REGEX,
1129         serde_api::SERDE_API_MISUSE,
1130         suspicious_trait_impl::SUSPICIOUS_ARITHMETIC_IMPL,
1131         suspicious_trait_impl::SUSPICIOUS_OP_ASSIGN_IMPL,
1132         swap::ALMOST_SWAPPED,
1133         transmute::WRONG_TRANSMUTE,
1134         transmuting_null::TRANSMUTING_NULL,
1135         types::ABSURD_EXTREME_COMPARISONS,
1136         types::CAST_PTR_ALIGNMENT,
1137         types::CAST_REF_TO_MUT,
1138         types::UNIT_CMP,
1139         unicode::ZERO_WIDTH_SPACE,
1140         unused_io_amount::UNUSED_IO_AMOUNT,
1141         unwrap::PANICKING_UNWRAP,
1142     ]);
1143
1144     reg.register_lint_group("clippy::perf", Some("clippy_perf"), vec![
1145         bytecount::NAIVE_BYTECOUNT,
1146         entry::MAP_ENTRY,
1147         escape::BOXED_LOCAL,
1148         large_enum_variant::LARGE_ENUM_VARIANT,
1149         loops::MANUAL_MEMCPY,
1150         loops::NEEDLESS_COLLECT,
1151         methods::EXPECT_FUN_CALL,
1152         methods::ITER_NTH,
1153         methods::OR_FUN_CALL,
1154         methods::SINGLE_CHAR_PATTERN,
1155         misc::CMP_OWNED,
1156         mutex_atomic::MUTEX_ATOMIC,
1157         slow_vector_initialization::SLOW_VECTOR_INITIALIZATION,
1158         trivially_copy_pass_by_ref::TRIVIALLY_COPY_PASS_BY_REF,
1159         types::BOX_VEC,
1160         vec::USELESS_VEC,
1161     ]);
1162
1163     reg.register_lint_group("clippy::cargo", Some("clippy_cargo"), vec![
1164         cargo_common_metadata::CARGO_COMMON_METADATA,
1165         multiple_crate_versions::MULTIPLE_CRATE_VERSIONS,
1166         wildcard_dependencies::WILDCARD_DEPENDENCIES,
1167     ]);
1168
1169     reg.register_lint_group("clippy::nursery", Some("clippy_nursery"), vec![
1170         attrs::EMPTY_LINE_AFTER_OUTER_ATTR,
1171         fallible_impl_from::FALLIBLE_IMPL_FROM,
1172         missing_const_for_fn::MISSING_CONST_FOR_FN,
1173         mutex_atomic::MUTEX_INTEGER,
1174         needless_borrow::NEEDLESS_BORROW,
1175         path_buf_push_overwrite::PATH_BUF_PUSH_OVERWRITE,
1176         redundant_clone::REDUNDANT_CLONE,
1177     ]);
1178 }
1179
1180 #[rustfmt::skip]
1181 fn register_removed_non_tool_lints(store: &mut rustc::lint::LintStore) {
1182     store.register_removed(
1183         "should_assert_eq",
1184         "`assert!()` will be more flexible with RFC 2011",
1185     );
1186     store.register_removed(
1187         "extend_from_slice",
1188         "`.extend_from_slice(_)` is a faster way to extend a Vec by a slice",
1189     );
1190     store.register_removed(
1191         "range_step_by_zero",
1192         "`iterator.step_by(0)` panics nowadays",
1193     );
1194     store.register_removed(
1195         "unstable_as_slice",
1196         "`Vec::as_slice` has been stabilized in 1.7",
1197     );
1198     store.register_removed(
1199         "unstable_as_mut_slice",
1200         "`Vec::as_mut_slice` has been stabilized in 1.7",
1201     );
1202     store.register_removed(
1203         "str_to_string",
1204         "using `str::to_string` is common even today and specialization will likely happen soon",
1205     );
1206     store.register_removed(
1207         "string_to_string",
1208         "using `string::to_string` is common even today and specialization will likely happen soon",
1209     );
1210     store.register_removed(
1211         "misaligned_transmute",
1212         "this lint has been split into cast_ptr_alignment and transmute_ptr_to_ptr",
1213     );
1214     store.register_removed(
1215         "assign_ops",
1216         "using compound assignment operators (e.g., `+=`) is harmless",
1217     );
1218     store.register_removed(
1219         "if_let_redundant_pattern_matching",
1220         "this lint has been changed to redundant_pattern_matching",
1221     );
1222     store.register_removed(
1223         "unsafe_vector_initialization",
1224         "the replacement suggested by this lint had substantially different behavior",
1225     );
1226 }
1227
1228 /// Register renamed lints.
1229 ///
1230 /// Used in `./src/driver.rs`.
1231 pub fn register_renamed(ls: &mut rustc::lint::LintStore) {
1232     ls.register_renamed("clippy::stutter", "clippy::module_name_repetitions");
1233     ls.register_renamed("clippy::new_without_default_derive", "clippy::new_without_default");
1234     ls.register_renamed("clippy::cyclomatic_complexity", "clippy::cognitive_complexity");
1235     ls.register_renamed("clippy::const_static_lifetime", "clippy::redundant_static_lifetimes");
1236 }
1237
1238 // only exists to let the dogfood integration test works.
1239 // Don't run clippy as an executable directly
1240 #[allow(dead_code)]
1241 fn main() {
1242     panic!("Please use the cargo-clippy executable");
1243 }