From 28edd7ac090d621ad8fd0ebe220d897d9df386a9 Mon Sep 17 00:00:00 2001 From: Maybe Waffle Date: Sat, 15 Jan 2022 02:04:58 +0300 Subject: [PATCH] Use `Symbol` for dup check in `#[rustc_must_implement_one_of]` --- compiler/rustc_typeck/src/collect.rs | 11 +++-------- 1 file changed, 3 insertions(+), 8 deletions(-) diff --git a/compiler/rustc_typeck/src/collect.rs b/compiler/rustc_typeck/src/collect.rs index 23b328b9186..84315cb6827 100644 --- a/compiler/rustc_typeck/src/collect.rs +++ b/compiler/rustc_typeck/src/collect.rs @@ -1306,18 +1306,13 @@ fn trait_def(tcx: TyCtxt<'_>, def_id: DefId) -> ty::TraitDef { }) // Check for duplicates .and_then(|list| { - let mut set: FxHashSet<&Ident> = FxHashSet::default(); + let mut set: FxHashMap = FxHashMap::default(); let mut no_dups = true; for ident in &*list { - if let Some(dup) = set.replace(ident) { - let dup2 = set.get(&dup).copied().unwrap(); // We've just inserted it - + if let Some(dup) = set.insert(ident.name, ident.span) { tcx.sess - .struct_span_err( - vec![dup.span, dup2.span], - "Functions names are duplicated", - ) + .struct_span_err(vec![dup, ident.span], "Functions names are duplicated") .note( "All `#[rustc_must_implement_one_of]` arguments \ must be unique",