Auto merge of #8431 - dswij:8416, r=xFrednet
`redundant_closure` fix FP on coerced closure Closes https://github.com/rust-lang/rust-clippy/issues/8416, Closes https://github.com/rust-lang/rust-clippy/issues/7812 Closes https://github.com/rust-lang/rust-clippy/issues/8091 ~~Seems like this is fixed in #817 and regressed.~~ Ignore coerced closure false positives, but this will lead to some false negatives on resolvable generics. IMO, this is still an overall improvement changelog: [`redundant_closure`] ignores coerced closure
This commit is contained in:
commit
d5c62fd399
@ -3,7 +3,7 @@ use clippy_utils::higher::VecArgs;
|
||||
use clippy_utils::source::snippet_opt;
|
||||
use clippy_utils::ty::is_type_diagnostic_item;
|
||||
use clippy_utils::usage::local_used_after_expr;
|
||||
use clippy_utils::{higher, path_to_local, path_to_local_id};
|
||||
use clippy_utils::{higher, is_adjusted, path_to_local, path_to_local_id};
|
||||
use if_chain::if_chain;
|
||||
use rustc_errors::Applicability;
|
||||
use rustc_hir::def_id::DefId;
|
||||
@ -103,6 +103,7 @@ impl<'tcx> LateLintPass<'tcx> for EtaReduction {
|
||||
let closure_ty = cx.typeck_results().expr_ty(expr);
|
||||
|
||||
if_chain!(
|
||||
if !is_adjusted(cx, &body.value);
|
||||
if let ExprKind::Call(callee, args) = body.value.kind;
|
||||
if let ExprKind::Path(_) = callee.kind;
|
||||
if check_inputs(cx, body.params, args);
|
||||
@ -144,6 +145,7 @@ impl<'tcx> LateLintPass<'tcx> for EtaReduction {
|
||||
);
|
||||
|
||||
if_chain!(
|
||||
if !is_adjusted(cx, &body.value);
|
||||
if let ExprKind::MethodCall(path, args, _) = body.value.kind;
|
||||
if check_inputs(cx, body.params, args);
|
||||
let method_def_id = cx.typeck_results().type_dependent_def_id(body.value.hir_id).unwrap();
|
||||
|
@ -37,7 +37,7 @@ fn main() {
|
||||
}
|
||||
|
||||
// See #815
|
||||
let e = Some(1u8).map(divergent);
|
||||
let e = Some(1u8).map(|a| divergent(a));
|
||||
let e = Some(1u8).map(generic);
|
||||
let e = Some(1u8).map(generic);
|
||||
// See #515
|
||||
@ -233,7 +233,7 @@ fn late_bound_lifetimes() {
|
||||
{
|
||||
}
|
||||
map_str(|s| take_asref_path(s));
|
||||
map_str_to_path(std::convert::AsRef::as_ref);
|
||||
map_str_to_path(|s| s.as_ref());
|
||||
}
|
||||
|
||||
mod type_param_bound {
|
||||
@ -279,3 +279,15 @@ mod bind_by_ref {
|
||||
Some(A).map(|ref a| B::from(a));
|
||||
}
|
||||
}
|
||||
|
||||
// #7812 False positive on coerced closure
|
||||
fn coerced_closure() {
|
||||
fn function_returning_unit<F: FnMut(i32)>(f: F) {}
|
||||
function_returning_unit(|x| std::process::exit(x));
|
||||
|
||||
fn arr() -> &'static [u8; 0] {
|
||||
&[]
|
||||
}
|
||||
fn slice_fn(_: impl FnOnce() -> &'static [u8]) {}
|
||||
slice_fn(|| arr());
|
||||
}
|
||||
|
@ -279,3 +279,15 @@ mod bind_by_ref {
|
||||
Some(A).map(|ref a| B::from(a));
|
||||
}
|
||||
}
|
||||
|
||||
// #7812 False positive on coerced closure
|
||||
fn coerced_closure() {
|
||||
fn function_returning_unit<F: FnMut(i32)>(f: F) {}
|
||||
function_returning_unit(|x| std::process::exit(x));
|
||||
|
||||
fn arr() -> &'static [u8; 0] {
|
||||
&[]
|
||||
}
|
||||
fn slice_fn(_: impl FnOnce() -> &'static [u8]) {}
|
||||
slice_fn(|| arr());
|
||||
}
|
||||
|
@ -24,12 +24,6 @@ error: redundant closure
|
||||
LL | all(&[1, 2, 3], &&2, |x, y| below(x, y)); //is adjusted
|
||||
| ^^^^^^^^^^^^^^^^^^ help: replace the closure with the function itself: `below`
|
||||
|
||||
error: redundant closure
|
||||
--> $DIR/eta.rs:40:27
|
||||
|
|
||||
LL | let e = Some(1u8).map(|a| divergent(a));
|
||||
| ^^^^^^^^^^^^^^^^ help: replace the closure with the function itself: `divergent`
|
||||
|
||||
error: redundant closure
|
||||
--> $DIR/eta.rs:41:27
|
||||
|
|
||||
@ -122,11 +116,5 @@ error: redundant closure
|
||||
LL | Some(1).map(|n| in_loop(n));
|
||||
| ^^^^^^^^^^^^^^ help: replace the closure with the function itself: `in_loop`
|
||||
|
||||
error: redundant closure
|
||||
--> $DIR/eta.rs:236:21
|
||||
|
|
||||
LL | map_str_to_path(|s| s.as_ref());
|
||||
| ^^^^^^^^^^^^^^ help: replace the closure with the method itself: `std::convert::AsRef::as_ref`
|
||||
|
||||
error: aborting due to 21 previous errors
|
||||
error: aborting due to 19 previous errors
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user