Skip to content

Commit

Permalink
Auto merge of #5920 - giraffate:fix_fp_for_redundant_closure_call, r=…
Browse files Browse the repository at this point in the history
…mikerite

Fix FP for `redundant_closure_call`

Fix #5916

changelog: Fix FP for `redundant_closure_call` when called in function body
  • Loading branch information
bors committed Aug 25, 2020
2 parents 8d9a485 + 9fe0ac3 commit 64b53f3
Show file tree
Hide file tree
Showing 4 changed files with 27 additions and 10 deletions.
19 changes: 12 additions & 7 deletions clippy_lints/src/redundant_closure_call.rs
Original file line number Diff line number Diff line change
Expand Up @@ -77,7 +77,7 @@ impl EarlyLintPass for RedundantClosureCall {
cx,
REDUNDANT_CLOSURE_CALL,
expr.span,
"try not to call a closure in the expression where it is declared.",
"try not to call a closure in the expression where it is declared",
|diag| {
if decl.inputs.is_empty() {
let mut app = Applicability::MachineApplicable;
Expand All @@ -95,12 +95,17 @@ impl EarlyLintPass for RedundantClosureCall {

impl<'tcx> LateLintPass<'tcx> for RedundantClosureCall {
fn check_block(&mut self, cx: &LateContext<'tcx>, block: &'tcx hir::Block<'_>) {
fn count_closure_usage<'tcx>(block: &'tcx hir::Block<'_>, path: &'tcx hir::Path<'tcx>) -> usize {
struct ClosureUsageCount<'tcx> {
fn count_closure_usage<'a, 'tcx>(
cx: &'a LateContext<'tcx>,
block: &'tcx hir::Block<'_>,
path: &'tcx hir::Path<'tcx>,
) -> usize {
struct ClosureUsageCount<'a, 'tcx> {
cx: &'a LateContext<'tcx>,
path: &'tcx hir::Path<'tcx>,
count: usize,
};
impl<'tcx> hir_visit::Visitor<'tcx> for ClosureUsageCount<'tcx> {
impl<'a, 'tcx> hir_visit::Visitor<'tcx> for ClosureUsageCount<'a, 'tcx> {
type Map = Map<'tcx>;

fn visit_expr(&mut self, expr: &'tcx hir::Expr<'tcx>) {
Expand All @@ -117,10 +122,10 @@ impl<'tcx> LateLintPass<'tcx> for RedundantClosureCall {
}

fn nested_visit_map(&mut self) -> hir_visit::NestedVisitorMap<Self::Map> {
hir_visit::NestedVisitorMap::None
hir_visit::NestedVisitorMap::OnlyBodies(self.cx.tcx.hir())
}
};
let mut closure_usage_count = ClosureUsageCount { path, count: 0 };
let mut closure_usage_count = ClosureUsageCount { cx, path, count: 0 };
closure_usage_count.visit_block(block);
closure_usage_count.count
}
Expand All @@ -136,7 +141,7 @@ impl<'tcx> LateLintPass<'tcx> for RedundantClosureCall {
if let hir::ExprKind::Call(ref closure, _) = call.kind;
if let hir::ExprKind::Path(hir::QPath::Resolved(_, ref path)) = closure.kind;
if ident == path.segments[0].ident;
if count_closure_usage(block, path) == 1;
if count_closure_usage(cx, block, path) == 1;
then {
span_lint(
cx,
Expand Down
4 changes: 2 additions & 2 deletions tests/ui/redundant_closure_call_early.stderr
Original file line number Diff line number Diff line change
@@ -1,12 +1,12 @@
error: try not to call a closure in the expression where it is declared.
error: try not to call a closure in the expression where it is declared
--> $DIR/redundant_closure_call_early.rs:9:17
|
LL | let mut k = (|m| m + 1)(i);
| ^^^^^^^^^^^^^^
|
= note: `-D clippy::redundant-closure-call` implied by `-D warnings`

error: try not to call a closure in the expression where it is declared.
error: try not to call a closure in the expression where it is declared
--> $DIR/redundant_closure_call_early.rs:12:9
|
LL | k = (|a, b| a * b)(1, 5);
Expand Down
2 changes: 1 addition & 1 deletion tests/ui/redundant_closure_call_fixable.stderr
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
error: try not to call a closure in the expression where it is declared.
error: try not to call a closure in the expression where it is declared
--> $DIR/redundant_closure_call_fixable.rs:7:13
|
LL | let a = (|| 42)();
Expand Down
12 changes: 12 additions & 0 deletions tests/ui/redundant_closure_call_late.rs
Original file line number Diff line number Diff line change
Expand Up @@ -24,4 +24,16 @@ fn main() {
let shadowed_closure = || 2;
i = shadowed_closure();
i = shadowed_closure();

// Fix FP in #5916
let mut x;
let create = || 2 * 2;
x = create();
fun(move || {
x = create();
})
}

fn fun<T: 'static + FnMut()>(mut f: T) {
f();
}

0 comments on commit 64b53f3

Please sign in to comment.