about summary refs log tree commit diff
diff options
context:
space:
mode:
authorManas <manas18244@iiitd.ac.in>2022-06-27 16:17:06 +0530
committerManas <manas18244@iiitd.ac.in>2022-06-27 16:17:06 +0530
commit7f1fac7c26bb73447dc105a81e8c9187e05cbbae (patch)
tree67ca3c809cdbcffc5cc79315aa44f323f235b203
parentb74e96f509baf0be70281c55f14cb18fefbc6b22 (diff)
downloadrust-7f1fac7c26bb73447dc105a81e8c9187e05cbbae.tar.gz
rust-7f1fac7c26bb73447dc105a81e8c9187e05cbbae.zip
fix: deduplicate cfg completions
cfg completions are duplicated if they are set with multiple values.
This patch deduplicates them.
-rw-r--r--crates/ide-completion/src/completions/attribute/cfg.rs3
1 files changed, 2 insertions, 1 deletions
diff --git a/crates/ide-completion/src/completions/attribute/cfg.rs b/crates/ide-completion/src/completions/attribute/cfg.rs
index b7e69d7b43c..b0a9fc8d43a 100644
--- a/crates/ide-completion/src/completions/attribute/cfg.rs
+++ b/crates/ide-completion/src/completions/attribute/cfg.rs
@@ -3,6 +3,7 @@
 use std::iter;
 
 use ide_db::SymbolKind;
+use itertools::Itertools;
 use syntax::SyntaxKind;
 
 use crate::{completions::Completions, context::CompletionContext, CompletionItem};
@@ -34,7 +35,7 @@ pub(crate) fn complete_cfg(acc: &mut Completions, ctx: &CompletionContext) {
 
             acc.add(item.build());
         }),
-        None => ctx.krate.potential_cfg(ctx.db).get_cfg_keys().cloned().for_each(|s| {
+        None => ctx.krate.potential_cfg(ctx.db).get_cfg_keys().cloned().unique().for_each(|s| {
             let item = CompletionItem::new(SymbolKind::BuiltinAttr, ctx.source_range(), s);
             acc.add(item.build());
         }),