X-Git-Url: https://git.lizzy.rs/?a=blobdiff_plain;f=clippy_lints%2Fsrc%2Fneedless_pass_by_value.rs;h=dc18a745c265127d57b82cddd715f16f6e778d2a;hb=2ff568d746e4641b992c0b74bea046e43a637997;hp=eaae13377ac55c76a519b7e8fb12280ba70e890b;hpb=a4c201e6b4f6ef2d2c12a70bbc61136ce22f15f8;p=rust.git diff --git a/clippy_lints/src/needless_pass_by_value.rs b/clippy_lints/src/needless_pass_by_value.rs index eaae13377ac..dc18a745c26 100644 --- a/clippy_lints/src/needless_pass_by_value.rs +++ b/clippy_lints/src/needless_pass_by_value.rs @@ -4,22 +4,21 @@ snippet, snippet_opt, span_lint_and_then, }; use if_chain::if_chain; -use matches::matches; -use rustc::declare_lint_pass; -use rustc::hir::intravisit::FnKind; -use rustc::hir::*; -use rustc::lint::{LateContext, LateLintPass, LintArray, LintPass}; -use rustc::traits; -use rustc::ty::{self, RegionKind, TypeFoldable}; +use rustc::ty::{self, TypeFoldable}; +use rustc_ast::ast::Attribute; use rustc_data_structures::fx::{FxHashMap, FxHashSet}; -use rustc_errors::Applicability; -use rustc_session::declare_tool_lint; +use rustc_errors::{Applicability, DiagnosticBuilder}; +use rustc_hir::intravisit::FnKind; +use rustc_hir::{BindingAnnotation, Body, FnDecl, GenericArg, HirId, ItemKind, Node, PatKind, QPath, TyKind}; +use rustc_infer::infer::TyCtxtInferExt; +use rustc_lint::{LateContext, LateLintPass}; +use rustc_session::{declare_lint_pass, declare_tool_lint}; +use rustc_span::{Span, Symbol}; use rustc_target::spec::abi::Abi; +use rustc_trait_selection::traits; +use rustc_trait_selection::traits::misc::can_type_implement_copy; use rustc_typeck::expr_use_visitor as euv; use std::borrow::Cow; -use syntax::ast::Attribute; -use syntax::errors::DiagnosticBuilder; -use syntax_pos::{Span, Symbol}; declare_clippy_lint! { /// **What it does:** Checks for functions taking arguments by value, but not @@ -92,7 +91,7 @@ fn check_fn( // Exclude non-inherent impls if let Some(Node::Item(item)) = cx.tcx.hir().find(cx.tcx.hir().get_parent_node(hir_id)) { - if matches!(item.kind, ItemKind::Impl(_, _, _, _, Some(_), _, _) | + if matches!(item.kind, ItemKind::Impl{ of_trait: Some(_), .. } | ItemKind::Trait(..)) { return; @@ -115,7 +114,7 @@ fn check_fn( let preds = traits::elaborate_predicates(cx.tcx, cx.param_env.caller_bounds.to_vec()) .filter(|p| !p.is_global()) .filter_map(|pred| { - if let ty::Predicate::Trait(poly_trait_ref) = pred { + if let ty::Predicate::Trait(poly_trait_ref, _) = pred { if poly_trait_ref.def_id() == sized_trait || poly_trait_ref.skip_binder().has_escaping_bound_vars() { return None; @@ -171,8 +170,9 @@ fn check_fn( ( preds.iter().any(|t| t.def_id() == borrow_trait), - !preds.is_empty() - && preds.iter().all(|t| { + !preds.is_empty() && { + let ty_empty_region = cx.tcx.mk_imm_ref(cx.tcx.lifetimes.re_root_empty, ty); + preds.iter().all(|t| { let ty_params = &t .skip_binder() .trait_ref @@ -181,8 +181,9 @@ fn check_fn( .skip(1) .cloned() .collect::>(); - implements_trait(cx, cx.tcx.mk_imm_ref(&RegionKind::ReEmpty, ty), t.def_id(), ty_params) - }), + implements_trait(cx, ty_empty_region, t.def_id(), ty_params) + }) + }, ) }; @@ -205,8 +206,8 @@ fn check_fn( let sugg = |db: &mut DiagnosticBuilder<'_>| { if let ty::Adt(def, ..) = ty.kind { if let Some(span) = cx.tcx.hir().span_if_local(def.did) { - if cx.param_env.can_type_implement_copy(cx.tcx, ty).is_ok() { - db.span_help(span, "consider marking this type as Copy"); + if can_type_implement_copy(cx.tcx, cx.param_env, ty).is_ok() { + db.span_help(span, "consider marking this type as `Copy`"); } } }