diff options
| author | Manas <manas18244@iiitd.ac.in> | 2022-06-27 16:17:06 +0530 |
|---|---|---|
| committer | Manas <manas18244@iiitd.ac.in> | 2022-06-27 16:17:06 +0530 |
| commit | 7f1fac7c26bb73447dc105a81e8c9187e05cbbae (patch) | |
| tree | 67ca3c809cdbcffc5cc79315aa44f323f235b203 | |
| parent | b74e96f509baf0be70281c55f14cb18fefbc6b22 (diff) | |
| download | rust-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.rs | 3 |
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()); }), |
