]> git.lizzy.rs Git - rust.git/commitdiff
Whitelist lints
authorGuillaume Gomez <guillaume1.gomez@gmail.com>
Thu, 5 Jul 2018 18:06:33 +0000 (20:06 +0200)
committerGuillaume Gomez <guillaume1.gomez@gmail.com>
Thu, 5 Jul 2018 18:06:33 +0000 (20:06 +0200)
src/librustc_lint/builtin.rs
src/librustc_lint/lib.rs
src/librustdoc/core.rs

index c5f3b45950ed7f86faf1e8631a6d65a0a75574fb..d6e5c70b8f7e1b4320788cf5c83e5bfef44849c7 100644 (file)
@@ -280,7 +280,7 @@ fn check_trait_item(&mut self, cx: &LateContext, item: &hir::TraitItem) {
 }
 
 declare_lint! {
-    MISSING_DOCS,
+    pub MISSING_DOCS,
     Allow,
     "detects missing documentation for public members"
 }
index adc700506ffc0bc15f271a2b3b365edca9711021..459f496c9fe05f2308cb56d94ae474b6c628d8db 100644 (file)
@@ -56,7 +56,7 @@
 use lint::FutureIncompatibleInfo;
 
 mod bad_style;
-mod builtin;
+pub mod builtin;
 mod types;
 mod unused;
 
index 5cfdd07ab92043e0f304cfe190976a9eacb56b00..c7a8e6804f6c9119a152341544bc884fa2ba4360 100644 (file)
@@ -189,6 +189,7 @@ pub fn run_core(search_paths: SearchPaths,
 
     let intra_link_resolution_failure_name = lint::builtin::INTRA_DOC_LINK_RESOLUTION_FAILURE.name;
     let warnings_lint_name = lint::builtin::WARNINGS.name;
+    let missing_docs = rustc_lint::builtin::MISSING_DOCS.name;
     let lints = lint::builtin::HardwiredLints.get_lints()
                     .into_iter()
                     .chain(rustc_lint::SoftLints.get_lints().into_iter())
@@ -236,12 +237,22 @@ pub fn run_core(search_paths: SearchPaths,
             sessopts, cpath, diagnostic_handler, codemap,
         );
 
-        let shutdown_lints = [lint::builtin::UNUSED_IMPORTS,
-                              lint::builtin::UNUSED_EXTERN_CRATES];
-
-        for l in &shutdown_lints {
-            sess.driver_lint_caps.insert(lint::LintId::of(l), lint::Allow);
-        }
+        lint::builtin::HardwiredLints.get_lints()
+                                     .into_iter()
+                                     .chain(rustc_lint::SoftLints.get_lints().into_iter())
+                                     .filter_map(|lint| {
+                                         if lint.name == warnings_lint_name ||
+                                            lint.name == intra_link_resolution_failure_name ||
+                                            lint.name == missing_docs {
+                                             None
+                                         } else {
+                                             Some(lint)
+                                         }
+                                     })
+                                     .for_each(|l| {
+                                         sess.driver_lint_caps.insert(lint::LintId::of(l),
+                                                                      lint::Allow);
+                                     });
 
         let codegen_backend = rustc_driver::get_codegen_backend(&sess);
         let cstore = Rc::new(CStore::new(codegen_backend.metadata_loader()));