mirror of
https://github.com/rust-lang/rust-analyzer
synced 2024-11-17 10:18:31 +00:00
Auto merge of #14299 - Veykril:local-search, r=Veykril
fix: Fix search not searching bodies of attributed items Closes https://github.com/rust-lang/rust-analyzer/issues/14229
This commit is contained in:
commit
de3b12d686
2 changed files with 24 additions and 42 deletions
|
@ -815,7 +815,7 @@ impl<'a> InFile<&'a SyntaxNode> {
|
||||||
/// Falls back to the macro call range if the node cannot be mapped up fully.
|
/// Falls back to the macro call range if the node cannot be mapped up fully.
|
||||||
///
|
///
|
||||||
/// For attributes and derives, this will point back to the attribute only.
|
/// For attributes and derives, this will point back to the attribute only.
|
||||||
/// For the entire item `InFile::use original_file_range_full`.
|
/// For the entire item use [`InFile::original_file_range_full`].
|
||||||
pub fn original_file_range(self, db: &dyn db::AstDatabase) -> FileRange {
|
pub fn original_file_range(self, db: &dyn db::AstDatabase) -> FileRange {
|
||||||
match self.file_id.repr() {
|
match self.file_id.repr() {
|
||||||
HirFileIdRepr::FileId(file_id) => FileRange { file_id, range: self.value.text_range() },
|
HirFileIdRepr::FileId(file_id) => FileRange { file_id, range: self.value.text_range() },
|
||||||
|
@ -830,6 +830,21 @@ impl<'a> InFile<&'a SyntaxNode> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Falls back to the macro call range if the node cannot be mapped up fully.
|
||||||
|
pub fn original_file_range_full(self, db: &dyn db::AstDatabase) -> FileRange {
|
||||||
|
match self.file_id.repr() {
|
||||||
|
HirFileIdRepr::FileId(file_id) => FileRange { file_id, range: self.value.text_range() },
|
||||||
|
HirFileIdRepr::MacroFile(mac_file) => {
|
||||||
|
if let Some(res) = self.original_file_range_opt(db) {
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
// Fall back to whole macro call.
|
||||||
|
let loc = db.lookup_intern_macro_call(mac_file.macro_call_id);
|
||||||
|
loc.kind.original_call_range_with_body(db)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// Attempts to map the syntax node back up its macro calls.
|
/// Attempts to map the syntax node back up its macro calls.
|
||||||
pub fn original_file_range_opt(self, db: &dyn db::AstDatabase) -> Option<FileRange> {
|
pub fn original_file_range_opt(self, db: &dyn db::AstDatabase) -> Option<FileRange> {
|
||||||
match ascend_node_border_tokens(db, self) {
|
match ascend_node_border_tokens(db, self) {
|
||||||
|
|
|
@ -244,14 +244,14 @@ impl Definition {
|
||||||
DefWithBody::Variant(v) => v.source(db).map(|src| src.syntax().cloned()),
|
DefWithBody::Variant(v) => v.source(db).map(|src| src.syntax().cloned()),
|
||||||
};
|
};
|
||||||
return match def {
|
return match def {
|
||||||
Some(def) => SearchScope::file_range(def.as_ref().original_file_range(db)),
|
Some(def) => SearchScope::file_range(def.as_ref().original_file_range_full(db)),
|
||||||
None => SearchScope::single_file(file_id),
|
None => SearchScope::single_file(file_id),
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
if let Definition::SelfType(impl_) = self {
|
if let Definition::SelfType(impl_) = self {
|
||||||
return match impl_.source(db).map(|src| src.syntax().cloned()) {
|
return match impl_.source(db).map(|src| src.syntax().cloned()) {
|
||||||
Some(def) => SearchScope::file_range(def.as_ref().original_file_range(db)),
|
Some(def) => SearchScope::file_range(def.as_ref().original_file_range_full(db)),
|
||||||
None => SearchScope::single_file(file_id),
|
None => SearchScope::single_file(file_id),
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@ -268,7 +268,7 @@ impl Definition {
|
||||||
hir::GenericDef::Const(it) => it.source(db).map(|src| src.syntax().cloned()),
|
hir::GenericDef::Const(it) => it.source(db).map(|src| src.syntax().cloned()),
|
||||||
};
|
};
|
||||||
return match def {
|
return match def {
|
||||||
Some(def) => SearchScope::file_range(def.as_ref().original_file_range(db)),
|
Some(def) => SearchScope::file_range(def.as_ref().original_file_range_full(db)),
|
||||||
None => SearchScope::single_file(file_id),
|
None => SearchScope::single_file(file_id),
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@ -319,10 +319,6 @@ impl Definition {
|
||||||
sema,
|
sema,
|
||||||
scope: None,
|
scope: None,
|
||||||
include_self_kw_refs: None,
|
include_self_kw_refs: None,
|
||||||
local_repr: match self {
|
|
||||||
Definition::Local(local) => Some(local),
|
|
||||||
_ => None,
|
|
||||||
},
|
|
||||||
search_self_mod: false,
|
search_self_mod: false,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -337,9 +333,6 @@ pub struct FindUsages<'a> {
|
||||||
assoc_item_container: Option<hir::AssocItemContainer>,
|
assoc_item_container: Option<hir::AssocItemContainer>,
|
||||||
/// whether to search for the `Self` type of the definition
|
/// whether to search for the `Self` type of the definition
|
||||||
include_self_kw_refs: Option<hir::Type>,
|
include_self_kw_refs: Option<hir::Type>,
|
||||||
/// the local representative for the local definition we are searching for
|
|
||||||
/// (this is required for finding all local declarations in a or-pattern)
|
|
||||||
local_repr: Option<hir::Local>,
|
|
||||||
/// whether to search for the `self` module
|
/// whether to search for the `self` module
|
||||||
search_self_mod: bool,
|
search_self_mod: bool,
|
||||||
}
|
}
|
||||||
|
@ -644,19 +637,6 @@ impl<'a> FindUsages<'a> {
|
||||||
sink: &mut dyn FnMut(FileId, FileReference) -> bool,
|
sink: &mut dyn FnMut(FileId, FileReference) -> bool,
|
||||||
) -> bool {
|
) -> bool {
|
||||||
match NameRefClass::classify(self.sema, name_ref) {
|
match NameRefClass::classify(self.sema, name_ref) {
|
||||||
Some(NameRefClass::Definition(def @ Definition::Local(local)))
|
|
||||||
if matches!(
|
|
||||||
self.local_repr, Some(repr) if repr == local
|
|
||||||
) =>
|
|
||||||
{
|
|
||||||
let FileRange { file_id, range } = self.sema.original_range(name_ref.syntax());
|
|
||||||
let reference = FileReference {
|
|
||||||
range,
|
|
||||||
name: ast::NameLike::NameRef(name_ref.clone()),
|
|
||||||
category: ReferenceCategory::new(&def, name_ref),
|
|
||||||
};
|
|
||||||
sink(file_id, reference)
|
|
||||||
}
|
|
||||||
Some(NameRefClass::Definition(def))
|
Some(NameRefClass::Definition(def))
|
||||||
if self.def == def
|
if self.def == def
|
||||||
// is our def a trait assoc item? then we want to find all assoc items from trait impls of our trait
|
// is our def a trait assoc item? then we want to find all assoc items from trait impls of our trait
|
||||||
|
@ -701,14 +681,16 @@ impl<'a> FindUsages<'a> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Some(NameRefClass::FieldShorthand { local_ref: local, field_ref: field }) => {
|
Some(NameRefClass::FieldShorthand { local_ref: local, field_ref: field }) => {
|
||||||
let field = Definition::Field(field);
|
|
||||||
let FileRange { file_id, range } = self.sema.original_range(name_ref.syntax());
|
let FileRange { file_id, range } = self.sema.original_range(name_ref.syntax());
|
||||||
|
|
||||||
|
let field = Definition::Field(field);
|
||||||
|
let local = Definition::Local(local);
|
||||||
let access = match self.def {
|
let access = match self.def {
|
||||||
Definition::Field(_) if field == self.def => {
|
Definition::Field(_) if field == self.def => {
|
||||||
ReferenceCategory::new(&field, name_ref)
|
ReferenceCategory::new(&field, name_ref)
|
||||||
}
|
}
|
||||||
Definition::Local(_) if matches!(self.local_repr, Some(repr) if repr == local) => {
|
Definition::Local(_) if local == self.def => {
|
||||||
ReferenceCategory::new(&Definition::Local(local), name_ref)
|
ReferenceCategory::new(&local, name_ref)
|
||||||
}
|
}
|
||||||
_ => return false,
|
_ => return false,
|
||||||
};
|
};
|
||||||
|
@ -752,21 +734,6 @@ impl<'a> FindUsages<'a> {
|
||||||
};
|
};
|
||||||
sink(file_id, reference)
|
sink(file_id, reference)
|
||||||
}
|
}
|
||||||
Some(NameClass::Definition(def @ Definition::Local(local))) if def != self.def => {
|
|
||||||
if matches!(
|
|
||||||
self.local_repr,
|
|
||||||
Some(repr) if local == repr
|
|
||||||
) {
|
|
||||||
let FileRange { file_id, range } = self.sema.original_range(name.syntax());
|
|
||||||
let reference = FileReference {
|
|
||||||
range,
|
|
||||||
name: ast::NameLike::Name(name.clone()),
|
|
||||||
category: None,
|
|
||||||
};
|
|
||||||
return sink(file_id, reference);
|
|
||||||
}
|
|
||||||
false
|
|
||||||
}
|
|
||||||
Some(NameClass::Definition(def)) if def != self.def => {
|
Some(NameClass::Definition(def)) if def != self.def => {
|
||||||
match (&self.assoc_item_container, self.def) {
|
match (&self.assoc_item_container, self.def) {
|
||||||
// for type aliases we always want to reference the trait def and all the trait impl counterparts
|
// for type aliases we always want to reference the trait def and all the trait impl counterparts
|
||||||
|
|
Loading…
Reference in a new issue