2021-03-25 18:29:11 +00:00
|
|
|
use clippy_utils::diagnostics::span_lint_and_sugg;
|
2021-04-22 09:31:13 +00:00
|
|
|
use clippy_utils::{is_expr_path_def_path, is_trait_method, paths};
|
2021-03-12 14:30:50 +00:00
|
|
|
use if_chain::if_chain;
|
|
|
|
use rustc_errors::Applicability;
|
|
|
|
use rustc_hir as hir;
|
|
|
|
use rustc_lint::LateContext;
|
2021-03-25 18:29:11 +00:00
|
|
|
use rustc_span::{source_map::Span, sym};
|
2021-03-12 14:30:50 +00:00
|
|
|
|
|
|
|
use super::FLAT_MAP_IDENTITY;
|
|
|
|
|
|
|
|
/// lint use of `flat_map` for `Iterators` where `flatten` would be sufficient
|
|
|
|
pub(super) fn check<'tcx>(
|
|
|
|
cx: &LateContext<'tcx>,
|
|
|
|
expr: &'tcx hir::Expr<'_>,
|
2021-04-08 15:50:13 +00:00
|
|
|
flat_map_arg: &'tcx hir::Expr<'_>,
|
2021-03-12 14:30:50 +00:00
|
|
|
flat_map_span: Span,
|
|
|
|
) {
|
2021-03-25 18:29:11 +00:00
|
|
|
if is_trait_method(cx, expr, sym::Iterator) {
|
2021-03-12 14:30:50 +00:00
|
|
|
let apply_lint = |message: &str| {
|
|
|
|
span_lint_and_sugg(
|
|
|
|
cx,
|
|
|
|
FLAT_MAP_IDENTITY,
|
|
|
|
flat_map_span.with_hi(expr.span.hi()),
|
|
|
|
message,
|
|
|
|
"try",
|
|
|
|
"flatten()".to_string(),
|
|
|
|
Applicability::MachineApplicable,
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
if_chain! {
|
2021-04-22 09:31:13 +00:00
|
|
|
if let hir::ExprKind::Closure(_, _, body_id, _, _) = flat_map_arg.kind;
|
|
|
|
let body = cx.tcx.hir().body(body_id);
|
2021-03-12 14:30:50 +00:00
|
|
|
|
|
|
|
if let hir::PatKind::Binding(_, _, binding_ident, _) = body.params[0].pat.kind;
|
2021-04-08 15:50:13 +00:00
|
|
|
if let hir::ExprKind::Path(hir::QPath::Resolved(_, path)) = body.value.kind;
|
2021-03-12 14:30:50 +00:00
|
|
|
|
|
|
|
if path.segments.len() == 1;
|
|
|
|
if path.segments[0].ident.name == binding_ident.name;
|
|
|
|
|
|
|
|
then {
|
|
|
|
apply_lint("called `flat_map(|x| x)` on an `Iterator`");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-04-22 09:31:13 +00:00
|
|
|
if is_expr_path_def_path(cx, flat_map_arg, &paths::CONVERT_IDENTITY) {
|
|
|
|
apply_lint("called `flat_map(std::convert::identity)` on an `Iterator`");
|
2021-03-12 14:30:50 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|