From 68626e4ef5acfea05812b68f41efa2bcd5bea448 Mon Sep 17 00:00:00 2001 From: Kirill Bulatov Date: Sun, 17 Jan 2021 00:53:15 +0200 Subject: Draft the working completion --- crates/ide_db/src/helpers/import_assets.rs | 30 ++++++++++++++++++++---------- 1 file changed, 20 insertions(+), 10 deletions(-) (limited to 'crates/ide_db/src/helpers') diff --git a/crates/ide_db/src/helpers/import_assets.rs b/crates/ide_db/src/helpers/import_assets.rs index e284220c1..a080b6ca7 100644 --- a/crates/ide_db/src/helpers/import_assets.rs +++ b/crates/ide_db/src/helpers/import_assets.rs @@ -5,7 +5,7 @@ use rustc_hash::FxHashSet; use syntax::{ast, AstNode}; use crate::{ - imports_locator::{self, AssocItemSearch}, + imports_locator::{self, AssocItemSearch, DEFAULT_QUERY_SEARCH_LIMIT}, RootDatabase, }; @@ -173,6 +173,7 @@ impl ImportAssets { let current_crate = self.module_with_candidate.krate(); let filter = |candidate: Either| { + // TODO kb process all traits at once instead? trait_candidates.clear(); match &self.import_candidate { ImportCandidate::TraitAssocItem(trait_candidate) => { @@ -191,6 +192,11 @@ impl ImportAssets { None, |_, assoc| { if canidate_assoc_item == assoc { + if let AssocItem::Function(f) = assoc { + if f.self_param(db).is_some() { + return None; + } + } Some(assoc_to_module_def(assoc)) } else { None @@ -238,17 +244,21 @@ impl ImportAssets { // see https://github.com/rust-analyzer/rust-analyzer/pull/7293#issuecomment-761585032 // and https://rust-lang.zulipchat.com/#narrow/stream/185405-t-compiler.2Fwg-rls-2.2E0/topic/Blanket.20trait.20impls.20lookup // for the details - NameToImport::Fuzzy(fuzzy_name) => imports_locator::find_similar_imports( - sema, - current_crate, - fuzzy_name.clone(), - match self.import_candidate { + NameToImport::Fuzzy(fuzzy_name) => { + let (assoc_item_search, limit) = match self.import_candidate { ImportCandidate::TraitAssocItem(_) | ImportCandidate::TraitMethod(_) => { - AssocItemSearch::AssocItemsOnly + (AssocItemSearch::AssocItemsOnly, None) } - _ => AssocItemSearch::Exclude, - }, - ), + _ => (AssocItemSearch::Exclude, Some(DEFAULT_QUERY_SEARCH_LIMIT)), + }; + imports_locator::find_similar_imports( + sema, + current_crate, + fuzzy_name.clone(), + assoc_item_search, + limit, + ) + } }; let mut res = unfiltered_imports -- cgit v1.2.3