From 143a30aa519ecdb8b98bf6bf2c625f77920e7921 Mon Sep 17 00:00:00 2001 From: Lukas Wirth Date: Thu, 9 Dec 2021 19:18:11 +0100 Subject: [PATCH] Show case-insensitive exact matches instead of fuzzy flyimport for short paths --- .../replace_derive_with_manual_impl.rs | 2 +- .../src/completions/flyimport.rs | 14 +++----- crates/ide_completion/src/lib.rs | 2 +- crates/ide_completion/src/tests/flyimport.rs | 26 ++++++++------ crates/ide_db/src/helpers/import_assets.rs | 34 +++++++++++++++---- crates/ide_db/src/items_locator.rs | 10 +++--- 6 files changed, 55 insertions(+), 33 deletions(-) diff --git a/crates/ide_assists/src/handlers/replace_derive_with_manual_impl.rs b/crates/ide_assists/src/handlers/replace_derive_with_manual_impl.rs index 3e33c62144e..46bf4d7b463 100644 --- a/crates/ide_assists/src/handlers/replace_derive_with_manual_impl.rs +++ b/crates/ide_assists/src/handlers/replace_derive_with_manual_impl.rs @@ -65,7 +65,7 @@ pub(crate) fn replace_derive_with_manual_impl( let found_traits = items_locator::items_with_name( &ctx.sema, current_crate, - NameToImport::Exact(trait_path.segments().last()?.to_string()), + NameToImport::exact_case_sensitive(trait_path.segments().last()?.to_string()), items_locator::AssocItemSearch::Exclude, Some(items_locator::DEFAULT_QUERY_SEARCH_LIMIT.inner()), ) diff --git a/crates/ide_completion/src/completions/flyimport.rs b/crates/ide_completion/src/completions/flyimport.rs index 3a9c1b3beb7..8994c25475b 100644 --- a/crates/ide_completion/src/completions/flyimport.rs +++ b/crates/ide_completion/src/completions/flyimport.rs @@ -227,22 +227,18 @@ fn import_assets(ctx: &CompletionContext, fuzzy_name: String) -> Option NameToImport { + NameToImport::Exact(s, true) + } +} + impl NameToImport { pub fn text(&self) -> &str { match self { - NameToImport::Exact(text) => text.as_str(), + NameToImport::Exact(text, _) => text.as_str(), NameToImport::Fuzzy(text) => text.as_str(), } } @@ -140,7 +146,7 @@ impl ImportAssets { if let Some(_) = path.qualifier() { return None; } - let name = NameToImport::Exact(path.segment()?.name_ref()?.to_string()); + let name = NameToImport::exact_case_sensitive(path.segment()?.name_ref()?.to_string()); let candidate_node = attr.syntax().clone(); Some(Self { import_candidate: ImportCandidate::Path(PathImportCandidate { qualifier: None, name }), @@ -230,6 +236,18 @@ impl ImportAssets { self.search_for(sema, None) } + pub fn path_fuzzy_name_to_exact(&mut self, case_sensitive: bool) { + if let ImportCandidate::Path(PathImportCandidate { name: to_import, .. }) = + &mut self.import_candidate + { + let name = match to_import { + NameToImport::Fuzzy(name) => std::mem::take(name), + _ => return, + }; + *to_import = NameToImport::Exact(name, case_sensitive); + } + } + fn search_for( &self, sema: &Semantics, @@ -561,7 +579,9 @@ impl ImportCandidate { Some(_) => None, None => Some(Self::TraitMethod(TraitImportCandidate { receiver_ty: sema.type_of_expr(&method_call.receiver()?)?.adjusted(), - assoc_item_name: NameToImport::Exact(method_call.name_ref()?.to_string()), + assoc_item_name: NameToImport::exact_case_sensitive( + method_call.name_ref()?.to_string(), + ), })), } } @@ -573,7 +593,7 @@ impl ImportCandidate { path_import_candidate( sema, path.qualifier(), - NameToImport::Exact(path.segment()?.name_ref()?.to_string()), + NameToImport::exact_case_sensitive(path.segment()?.name_ref()?.to_string()), ) } @@ -587,7 +607,7 @@ impl ImportCandidate { } Some(ImportCandidate::Path(PathImportCandidate { qualifier: None, - name: NameToImport::Exact(name.to_string()), + name: NameToImport::exact_case_sensitive(name.to_string()), })) } diff --git a/crates/ide_db/src/items_locator.rs b/crates/ide_db/src/items_locator.rs index e0dbe6caf0a..ca8266b6d24 100644 --- a/crates/ide_db/src/items_locator.rs +++ b/crates/ide_db/src/items_locator.rs @@ -50,16 +50,18 @@ pub fn items_with_name<'a>( }); let (mut local_query, mut external_query) = match name { - NameToImport::Exact(exact_name) => { + NameToImport::Exact(exact_name, case_sensitive) => { let mut local_query = symbol_index::Query::new(exact_name.clone()); local_query.exact(); let external_query = import_map::Query::new(exact_name) .name_only() - .search_mode(import_map::SearchMode::Equals) - .case_sensitive(); + .search_mode(import_map::SearchMode::Equals); - (local_query, external_query) + ( + local_query, + if case_sensitive { external_query.case_sensitive() } else { external_query }, + ) } NameToImport::Fuzzy(fuzzy_search_string) => { let mut local_query = symbol_index::Query::new(fuzzy_search_string.clone());