Revert "Exclude pattern guards from unnecessary_fold lint"
This reverts commit d3c06f7252
.
This commit is contained in:
parent
d3c06f7252
commit
863c8e26fc
@ -9,7 +9,6 @@
|
||||
|
||||
|
||||
use crate::rustc::hir;
|
||||
use crate::rustc::hir::{ExprKind, Guard, Node};
|
||||
use crate::rustc::hir::def::Def;
|
||||
use crate::rustc::lint::{in_external_macro, LateContext, LateLintPass, Lint, LintArray, LintContext, LintPass};
|
||||
use crate::rustc::ty::{self, Ty};
|
||||
@ -1429,23 +1428,6 @@ fn lint_unnecessary_fold(cx: &LateContext<'_, '_>, expr: &hir::Expr, fold_args:
|
||||
return;
|
||||
}
|
||||
|
||||
// `Iterator::any` cannot be used within a pattern guard
|
||||
// See https://github.com/rust-lang-nursery/rust-clippy/issues/3069
|
||||
if_chain! {
|
||||
if let Some(fold_parent) = cx.tcx.hir.find(cx.tcx.hir.get_parent_node(expr.id));
|
||||
if let Node::Expr(fold_parent) = fold_parent;
|
||||
if let ExprKind::Match(_, ref arms, _) = fold_parent.node;
|
||||
if arms.iter().any(|arm| {
|
||||
if let Some(Guard::If(ref guard)) = arm.guard {
|
||||
return guard.id == expr.id;
|
||||
}
|
||||
false
|
||||
});
|
||||
then {
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
assert!(fold_args.len() == 3,
|
||||
"Expected fold_args to have three entries - the receiver, the initial value and the closure");
|
||||
|
||||
|
@ -45,13 +45,6 @@ fn unnecessary_fold_should_ignore() {
|
||||
|
||||
let _ = [(0..2), (0..3)].iter().fold(0, |a, b| a + b.len());
|
||||
let _ = [(0..2), (0..3)].iter().fold(1, |a, b| a * b.len());
|
||||
|
||||
// Because `any` takes the iterator as a mutable reference,
|
||||
// it cannot be used in a pattern guard, and we must use `fold`.
|
||||
match 1 {
|
||||
_ if (0..3).fold(false, |acc, x| acc || x > 2) => {}
|
||||
_ => {}
|
||||
}
|
||||
}
|
||||
|
||||
fn main() {}
|
||||
|
Loading…
Reference in New Issue
Block a user