1 use clippy_utils::diagnostics::span_lint_and_help;
2 use clippy_utils::{path_def_id, qpath_generic_tys};
3 use rustc_hir::{self as hir, def_id::DefId, QPath};
4 use rustc_lint::LateContext;
5 use rustc_span::{sym, Symbol};
7 use super::BOX_COLLECTION;
9 pub(super) fn check(cx: &LateContext<'_>, hir_ty: &hir::Ty<'_>, qpath: &QPath<'_>, def_id: DefId) -> bool {
11 if Some(def_id) == cx.tcx.lang_items().owned_box();
12 if let Some(item_type) = get_std_collection(cx, qpath);
14 let generic = match item_type {
23 "you seem to be trying to use `Box<{outer}{generic}>`. Consider using just `{outer}{generic}`",
28 "`{outer}{generic}` is already on the heap, `Box<{outer}{generic}>` makes an extra allocation",
39 fn get_std_collection(cx: &LateContext<'_>, qpath: &QPath<'_>) -> Option<Symbol> {
40 let param = qpath_generic_tys(qpath).next()?;
41 let id = path_def_id(cx, param)?;
43 .get_diagnostic_name(id)
44 .filter(|&name| matches!(name, sym::HashMap | sym::String | sym::Vec))