From 1ab96db7915f36bae5e1ad645861ef910b79904d Mon Sep 17 00:00:00 2001 From: Michael Wright Date: Sun, 1 Apr 2018 09:28:53 +0200 Subject: [PATCH 1/8] Make dogfood test output to seperate directory This commit makes `cargo clippy` output the build artifacts to a separate directory if the `CLIPPY_DOGFOOD` env var is set. This should prevent dogfood builds from interfering with regular builds. This should help with issue #2595. --- src/main.rs | 17 +++++++++++++++++ tests/dogfood.rs | 1 + 2 files changed, 18 insertions(+) diff --git a/src/main.rs b/src/main.rs index 5bdbaf1bc80e..0baeab7338eb 100644 --- a/src/main.rs +++ b/src/main.rs @@ -77,10 +77,27 @@ where if cfg!(windows) { path.set_extension("exe"); } + + let mut extra_envs = vec![]; + if let Ok(_) = std::env::var("CLIPPY_DOGFOOD") { + let target_dir = std::env::var("CARGO_MANIFEST_DIR") + .map(|m| { + std::path::PathBuf::from(m) + .join("target") + .join("dogfood") + .to_string_lossy() + .into_owned() + }) + .unwrap_or("clippy_dogfood".to_string()); + + extra_envs.push(("CARGO_TARGET_DIR", target_dir)); + }; + let exit_status = std::process::Command::new("cargo") .args(&args) .env("RUSTC_WRAPPER", path) .env("CLIPPY_ARGS", clippy_args) + .envs(extra_envs) .spawn() .expect("could not run cargo") .wait() diff --git a/tests/dogfood.rs b/tests/dogfood.rs index ed6451a3eb68..a2d4da9a1ca4 100644 --- a/tests/dogfood.rs +++ b/tests/dogfood.rs @@ -15,6 +15,7 @@ fn dogfood() { .arg("cargo-clippy") .arg("--manifest-path") .arg(root_dir.join("Cargo.toml")) + .env("CLIPPY_DOGFOOD", "true") .output() .unwrap(); println!("status: {}", output.status); From 609dd47410cac010a9a73e96a4b7237793d73ad5 Mon Sep 17 00:00:00 2001 From: Michael Wright Date: Sun, 1 Apr 2018 10:17:48 +0200 Subject: [PATCH 2/8] Fix clippy warnings from last commit --- src/main.rs | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/main.rs b/src/main.rs index 0baeab7338eb..5cc6fd674eb3 100644 --- a/src/main.rs +++ b/src/main.rs @@ -79,7 +79,7 @@ where } let mut extra_envs = vec![]; - if let Ok(_) = std::env::var("CLIPPY_DOGFOOD") { + if std::env::var("CLIPPY_DOGFOOD").is_ok() { let target_dir = std::env::var("CARGO_MANIFEST_DIR") .map(|m| { std::path::PathBuf::from(m) @@ -88,7 +88,7 @@ where .to_string_lossy() .into_owned() }) - .unwrap_or("clippy_dogfood".to_string()); + .unwrap_or_else(|_| "clippy_dogfood".to_string()); extra_envs.push(("CARGO_TARGET_DIR", target_dir)); }; From 6397131f8a2ebef377a62094a02c2e8637cb9aca Mon Sep 17 00:00:00 2001 From: Michael Wright Date: Mon, 2 Apr 2018 06:22:10 +0200 Subject: [PATCH 3/8] Fix clippy warning Allow `many_single_char_names` on `SpanlessHash::hash_expr`. Each variable has a small scope and the method is readable. --- clippy_lints/src/utils/hir_utils.rs | 1 + 1 file changed, 1 insertion(+) diff --git a/clippy_lints/src/utils/hir_utils.rs b/clippy_lints/src/utils/hir_utils.rs index e790184a7aba..1f96ec2b237c 100644 --- a/clippy_lints/src/utils/hir_utils.rs +++ b/clippy_lints/src/utils/hir_utils.rs @@ -316,6 +316,7 @@ impl<'a, 'tcx: 'a> SpanlessHash<'a, 'tcx> { b.rules.hash(&mut self.s); } + #[allow(many_single_char_names)] pub fn hash_expr(&mut self, e: &Expr) { if let Some(e) = constant_simple(self.cx, e) { return e.hash(&mut self.s); From 57af95b6f5d8126bf967022e182b1973e2771d38 Mon Sep 17 00:00:00 2001 From: Michael Wright Date: Mon, 2 Apr 2018 06:34:11 +0200 Subject: [PATCH 4/8] Fix clippy warning Fix `option_option` warning on `to_const_range` by taking the entire range as an parameter instead of the start and end. --- clippy_lints/src/array_indexing.rs | 21 ++++++++------------- 1 file changed, 8 insertions(+), 13 deletions(-) diff --git a/clippy_lints/src/array_indexing.rs b/clippy_lints/src/array_indexing.rs index 4563a58f7abd..1b21cf8c5ff4 100644 --- a/clippy_lints/src/array_indexing.rs +++ b/clippy_lints/src/array_indexing.rs @@ -3,6 +3,7 @@ use rustc::ty; use rustc::hir; use syntax::ast::RangeLimits; use utils::{self, higher}; +use utils::higher::Range; use consts::{constant, Constant}; /// **What it does:** Checks for out of bounds array indexing with a constant @@ -73,10 +74,7 @@ impl<'a, 'tcx> LateLintPass<'a, 'tcx> for ArrayIndexing { // Index is a constant range if let Some(range) = higher::range(index) { - let start = range.start.map(|start| constant(cx, start).map(|(c, _)| c)); - let end = range.end.map(|end| constant(cx, end).map(|(c, _)| c)); - - if let Some((start, end)) = to_const_range(&start, &end, range.limits, size) { + if let Some((start, end)) = to_const_range(cx, range, size) { if start > size || end > size { utils::span_lint(cx, OUT_OF_BOUNDS_INDEXING, e.span, "range is out of bounds"); } @@ -102,20 +100,17 @@ impl<'a, 'tcx> LateLintPass<'a, 'tcx> for ArrayIndexing { /// Returns an option containing a tuple with the start and end (exclusive) of /// the range. -fn to_const_range( - start: &Option>, - end: &Option>, - limits: RangeLimits, - array_size: u128, -) -> Option<(u128, u128)> { - let start = match *start { +fn to_const_range<'a, 'tcx>(cx: &LateContext<'a, 'tcx>, range: Range, array_size: u128) -> Option<(u128, u128)> { + let s = range.start.map(|expr| constant(cx, expr).map(|(c, _)| c)); + let start = match s { Some(Some(Constant::Int(x))) => x, Some(_) => return None, None => 0, }; - let end = match *end { - Some(Some(Constant::Int(x))) => if limits == RangeLimits::Closed { + let e = range.end.map(|expr| constant(cx, expr).map(|(c, _)| c)); + let end = match e { + Some(Some(Constant::Int(x))) => if range.limits == RangeLimits::Closed { x + 1 } else { x From 89cb0531462da0e6cc116b4b5ef86de908654447 Mon Sep 17 00:00:00 2001 From: Michael Wright Date: Mon, 2 Apr 2018 06:42:30 +0200 Subject: [PATCH 5/8] Fix clippy warning Fix cyclomatic_complexity warning on `check_expr` by allowing it. This is preferable to increasing the threshold every time the method changes. --- clippy_lints/src/methods.rs | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/clippy_lints/src/methods.rs b/clippy_lints/src/methods.rs index 50de299ca7d1..29e8a9a82b15 100644 --- a/clippy_lints/src/methods.rs +++ b/clippy_lints/src/methods.rs @@ -680,9 +680,7 @@ impl LintPass for Pass { } impl<'a, 'tcx> LateLintPass<'a, 'tcx> for Pass { - #[allow(unused_attributes)] - // ^ required because `cyclomatic_complexity` attribute shows up as unused - #[cyclomatic_complexity = "30"] + #[allow(cyclomatic_complexity)] fn check_expr(&mut self, cx: &LateContext<'a, 'tcx>, expr: &'tcx hir::Expr) { if in_macro(expr.span) { return; From fcabbeb251bedabce6b45b8c4db6ec15e6002b82 Mon Sep 17 00:00:00 2001 From: Michael Wright Date: Mon, 2 Apr 2018 06:57:14 +0200 Subject: [PATCH 6/8] Fix clippy warning Fix too_many_arguments on `check_general_case` by allowing it. I can't see a sensible way of grouping the parameters. --- clippy_lints/src/methods.rs | 1 + 1 file changed, 1 insertion(+) diff --git a/clippy_lints/src/methods.rs b/clippy_lints/src/methods.rs index 29e8a9a82b15..423be2106d16 100644 --- a/clippy_lints/src/methods.rs +++ b/clippy_lints/src/methods.rs @@ -887,6 +887,7 @@ fn lint_or_fun_call(cx: &LateContext, expr: &hir::Expr, method_span: Span, name: } /// Check for `*or(foo())`. + #[allow(too_many_arguments)] fn check_general_case( cx: &LateContext, name: &str, From e91404bcc3908f7ff4ea82003cd21230e4d34acd Mon Sep 17 00:00:00 2001 From: Michael Wright Date: Mon, 2 Apr 2018 07:35:13 +0200 Subject: [PATCH 7/8] Fix clippy warning --- clippy_lints/src/utils/mod.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/clippy_lints/src/utils/mod.rs b/clippy_lints/src/utils/mod.rs index e3a7fc851b15..f71de382cade 100644 --- a/clippy_lints/src/utils/mod.rs +++ b/clippy_lints/src/utils/mod.rs @@ -1103,7 +1103,7 @@ pub fn without_block_comments(lines: Vec<&str>) -> Vec<&str> { let mut nest_level = 0; - for line in lines.into_iter() { + for line in lines { if line.contains("/*") { nest_level += 1; continue; From add4434ee37d8ee87df63852cf86f02d4c3992a1 Mon Sep 17 00:00:00 2001 From: Michael Wright Date: Mon, 2 Apr 2018 09:28:08 +0200 Subject: [PATCH 8/8] Support non-unicode paths for dogfood test --- src/main.rs | 33 ++++++++++++++++++--------------- 1 file changed, 18 insertions(+), 15 deletions(-) diff --git a/src/main.rs b/src/main.rs index 5cc6fd674eb3..aac5e97f3114 100644 --- a/src/main.rs +++ b/src/main.rs @@ -78,26 +78,29 @@ where path.set_extension("exe"); } - let mut extra_envs = vec![]; - if std::env::var("CLIPPY_DOGFOOD").is_ok() { - let target_dir = std::env::var("CARGO_MANIFEST_DIR") - .map(|m| { - std::path::PathBuf::from(m) - .join("target") - .join("dogfood") - .to_string_lossy() - .into_owned() - }) - .unwrap_or_else(|_| "clippy_dogfood".to_string()); - - extra_envs.push(("CARGO_TARGET_DIR", target_dir)); - }; + let target_dir = std::env::var_os("CLIPPY_DOGFOOD") + .map(|_| { + std::env::var_os("CARGO_MANIFEST_DIR").map_or_else( + || { + let mut fallback = std::ffi::OsString::new(); + fallback.push("clippy_dogfood"); + fallback + }, + |d| { + std::path::PathBuf::from(d) + .join("target") + .join("dogfood") + .into_os_string() + }, + ) + }) + .map(|p| ("CARGO_TARGET_DIR", p)); let exit_status = std::process::Command::new("cargo") .args(&args) .env("RUSTC_WRAPPER", path) .env("CLIPPY_ARGS", clippy_args) - .envs(extra_envs) + .envs(target_dir) .spawn() .expect("could not run cargo") .wait()