aboutsummaryrefslogtreecommitdiff
path: root/crates
diff options
context:
space:
mode:
authorLukas Wirth <[email protected]>2021-02-09 15:03:39 +0000
committerLukas Wirth <[email protected]>2021-02-12 17:58:29 +0000
commitc5be0b2589e5ed732ae5001122e453f0903bfdf2 (patch)
treee60864d41fd22f995b424b057f4e225609577c26 /crates
parentd644728d82df10b034d0ea736590c781afa2ba15 (diff)
Use NameLike in FileReference directly as its not exported from ide anymore
Diffstat (limited to 'crates')
-rw-r--r--crates/assists/src/handlers/inline_local_variable.rs3
-rw-r--r--crates/ide/src/lib.rs2
-rw-r--r--crates/ide/src/references.rs8
-rw-r--r--crates/ide/src/references/rename.rs12
-rw-r--r--crates/ide_db/src/search.rs63
5 files changed, 29 insertions, 59 deletions
diff --git a/crates/assists/src/handlers/inline_local_variable.rs b/crates/assists/src/handlers/inline_local_variable.rs
index e4f984713..8d28431cf 100644
--- a/crates/assists/src/handlers/inline_local_variable.rs
+++ b/crates/assists/src/handlers/inline_local_variable.rs
@@ -124,11 +124,10 @@ pub(crate) fn inline_local_variable(acc: &mut Assists, ctx: &AssistContext) -> O
124 move |builder| { 124 move |builder| {
125 builder.delete(delete_range); 125 builder.delete(delete_range);
126 for (file_id, references) in usages.references { 126 for (file_id, references) in usages.references {
127 let root = ctx.sema.parse(file_id);
128 for (&should_wrap, reference) in wrap_in_parens[&file_id].iter().zip(references) { 127 for (&should_wrap, reference) in wrap_in_parens[&file_id].iter().zip(references) {
129 let replacement = 128 let replacement =
130 if should_wrap { init_in_paren.clone() } else { init_str.clone() }; 129 if should_wrap { init_in_paren.clone() } else { init_str.clone() };
131 match &reference.as_name_ref(root.syntax()) { 130 match reference.name.as_name_ref() {
132 Some(name_ref) 131 Some(name_ref)
133 if ast::RecordExprField::for_field_name(name_ref).is_some() => 132 if ast::RecordExprField::for_field_name(name_ref).is_some() =>
134 { 133 {
diff --git a/crates/ide/src/lib.rs b/crates/ide/src/lib.rs
index a245d9341..592b12925 100644
--- a/crates/ide/src/lib.rs
+++ b/crates/ide/src/lib.rs
@@ -94,7 +94,7 @@ pub use ide_db::{
94 call_info::CallInfo, 94 call_info::CallInfo,
95 label::Label, 95 label::Label,
96 line_index::{LineCol, LineIndex}, 96 line_index::{LineCol, LineIndex},
97 search::{FileReference, ReferenceAccess, SearchScope}, 97 search::{ReferenceAccess, SearchScope},
98 source_change::{FileSystemEdit, SourceChange}, 98 source_change::{FileSystemEdit, SourceChange},
99 symbol_index::Query, 99 symbol_index::Query,
100 RootDatabase, 100 RootDatabase,
diff --git a/crates/ide/src/references.rs b/crates/ide/src/references.rs
index f96fac9c1..77c208be9 100644
--- a/crates/ide/src/references.rs
+++ b/crates/ide/src/references.rs
@@ -66,12 +66,8 @@ pub(crate) fn find_all_refs(
66 let mut usages = def.usages(sema).set_scope(search_scope).all(); 66 let mut usages = def.usages(sema).set_scope(search_scope).all();
67 if let Some(ctor_filter) = ctor_filter { 67 if let Some(ctor_filter) = ctor_filter {
68 // filter for constructor-literals 68 // filter for constructor-literals
69 usages.references.iter_mut().for_each(|(&file_id, it)| { 69 usages.references.values_mut().for_each(|it| {
70 let root = sema.parse(file_id); 70 it.retain(|reference| reference.name.as_name_ref().map_or(false, ctor_filter));
71 let root = root.syntax();
72 it.retain(|reference| {
73 reference.as_name_ref(root).map_or(false, |name_ref| ctor_filter(&name_ref))
74 })
75 }); 71 });
76 usages.references.retain(|_, it| !it.is_empty()); 72 usages.references.retain(|_, it| !it.is_empty());
77 } 73 }
diff --git a/crates/ide/src/references/rename.rs b/crates/ide/src/references/rename.rs
index 64992c72d..b04214291 100644
--- a/crates/ide/src/references/rename.rs
+++ b/crates/ide/src/references/rename.rs
@@ -164,20 +164,18 @@ fn find_definition(
164} 164}
165 165
166fn source_edit_from_references( 166fn source_edit_from_references(
167 sema: &Semantics<RootDatabase>, 167 _sema: &Semantics<RootDatabase>,
168 file_id: FileId, 168 file_id: FileId,
169 references: &[FileReference], 169 references: &[FileReference],
170 def: Definition, 170 def: Definition,
171 new_name: &str, 171 new_name: &str,
172) -> (FileId, TextEdit) { 172) -> (FileId, TextEdit) {
173 let root = sema.parse(file_id);
174 let mut edit = TextEdit::builder(); 173 let mut edit = TextEdit::builder();
175 for reference in references { 174 for reference in references {
176 let (range, replacement) = match &reference.name_from_syntax(root.syntax()) { 175 let (range, replacement) = match &reference.name {
177 Some(NameLike::Name(_)) => (None, format!("{}", new_name)), 176 NameLike::Name(_) => (None, format!("{}", new_name)),
178 Some(NameLike::NameRef(name_ref)) => source_edit_from_name_ref(name_ref, new_name, def), 177 NameLike::NameRef(name_ref) => source_edit_from_name_ref(name_ref, new_name, def),
179 Some(NameLike::Lifetime(_)) => (None, format!("{}", new_name)), 178 NameLike::Lifetime(_) => (None, format!("{}", new_name)),
180 None => (None, new_name.to_owned()),
181 }; 179 };
182 // FIXME: Some(range) will be incorrect when we are inside macros 180 // FIXME: Some(range) will be incorrect when we are inside macros
183 edit.replace(range.unwrap_or(reference.range), replacement); 181 edit.replace(range.unwrap_or(reference.range), replacement);
diff --git a/crates/ide_db/src/search.rs b/crates/ide_db/src/search.rs
index d0aed26f7..38b20f2dc 100644
--- a/crates/ide_db/src/search.rs
+++ b/crates/ide_db/src/search.rs
@@ -10,9 +10,7 @@ use base_db::{FileId, FileRange, SourceDatabaseExt};
10use hir::{DefWithBody, HasSource, Module, ModuleSource, Semantics, Visibility}; 10use hir::{DefWithBody, HasSource, Module, ModuleSource, Semantics, Visibility};
11use once_cell::unsync::Lazy; 11use once_cell::unsync::Lazy;
12use rustc_hash::FxHashMap; 12use rustc_hash::FxHashMap;
13use syntax::{ 13use syntax::{ast, match_ast, AstNode, TextRange, TextSize};
14 ast, match_ast, AstNode, NodeOrToken, SyntaxElement, SyntaxNode, TextRange, TextSize,
15};
16 14
17use crate::defs::NameClass; 15use crate::defs::NameClass;
18use crate::{ 16use crate::{
@@ -20,13 +18,6 @@ use crate::{
20 RootDatabase, 18 RootDatabase,
21}; 19};
22 20
23#[derive(Debug, Clone)]
24pub enum NameKind {
25 Name,
26 NameRef,
27 Lifetime,
28}
29
30#[derive(Debug, Default, Clone)] 21#[derive(Debug, Default, Clone)]
31pub struct UsageSearchResult { 22pub struct UsageSearchResult {
32 pub references: FxHashMap<FileId, Vec<FileReference>>, 23 pub references: FxHashMap<FileId, Vec<FileReference>>,
@@ -68,6 +59,15 @@ pub enum NameLike {
68 Lifetime(ast::Lifetime), 59 Lifetime(ast::Lifetime),
69} 60}
70 61
62impl NameLike {
63 pub fn as_name_ref(&self) -> Option<&ast::NameRef> {
64 match self {
65 NameLike::NameRef(name_ref) => Some(name_ref),
66 _ => None,
67 }
68 }
69}
70
71mod __ { 71mod __ {
72 use super::{ 72 use super::{
73 ast::{Lifetime, Name, NameRef}, 73 ast::{Lifetime, Name, NameRef},
@@ -79,37 +79,10 @@ mod __ {
79#[derive(Debug, Clone)] 79#[derive(Debug, Clone)]
80pub struct FileReference { 80pub struct FileReference {
81 pub range: TextRange, 81 pub range: TextRange,
82 pub name: NameKind, 82 pub name: NameLike,
83 pub access: Option<ReferenceAccess>, 83 pub access: Option<ReferenceAccess>,
84} 84}
85 85
86impl FileReference {
87 pub fn name_from_syntax(&self, root: &SyntaxNode) -> Option<NameLike> {
88 let node = node_or_parent(root.covering_element(self.range));
89 match self.name {
90 NameKind::Name => ast::Name::cast(node).map(Into::into),
91 NameKind::NameRef => ast::NameRef::cast(node).map(Into::into),
92 NameKind::Lifetime => ast::Lifetime::cast(node).map(Into::into),
93 }
94 }
95
96 pub fn as_name_ref(&self, root: &SyntaxNode) -> Option<ast::NameRef> {
97 match self.name {
98 NameKind::NameRef => {
99 ast::NameRef::cast(node_or_parent(root.covering_element(self.range)))
100 }
101 _ => None,
102 }
103 }
104}
105
106fn node_or_parent(ele: SyntaxElement) -> SyntaxNode {
107 match ele {
108 NodeOrToken::Node(node) => node,
109 NodeOrToken::Token(token) => token.parent(),
110 }
111}
112
113#[derive(Debug, Copy, Clone, PartialEq)] 86#[derive(Debug, Copy, Clone, PartialEq)]
114pub enum ReferenceAccess { 87pub enum ReferenceAccess {
115 Read, 88 Read,
@@ -408,7 +381,11 @@ impl<'a> FindUsages<'a> {
408 match NameRefClass::classify_lifetime(self.sema, lifetime) { 381 match NameRefClass::classify_lifetime(self.sema, lifetime) {
409 Some(NameRefClass::Definition(def)) if &def == self.def => { 382 Some(NameRefClass::Definition(def)) if &def == self.def => {
410 let FileRange { file_id, range } = self.sema.original_range(lifetime.syntax()); 383 let FileRange { file_id, range } = self.sema.original_range(lifetime.syntax());
411 let reference = FileReference { range, name: NameKind::Lifetime, access: None }; 384 let reference = FileReference {
385 range,
386 name: NameLike::Lifetime(lifetime.clone()),
387 access: None,
388 };
412 sink(file_id, reference) 389 sink(file_id, reference)
413 } 390 }
414 _ => false, // not a usage 391 _ => false, // not a usage
@@ -425,7 +402,7 @@ impl<'a> FindUsages<'a> {
425 let FileRange { file_id, range } = self.sema.original_range(name_ref.syntax()); 402 let FileRange { file_id, range } = self.sema.original_range(name_ref.syntax());
426 let reference = FileReference { 403 let reference = FileReference {
427 range, 404 range,
428 name: NameKind::NameRef, 405 name: NameLike::NameRef(name_ref.clone()),
429 access: reference_access(&def, &name_ref), 406 access: reference_access(&def, &name_ref),
430 }; 407 };
431 sink(file_id, reference) 408 sink(file_id, reference)
@@ -435,12 +412,12 @@ impl<'a> FindUsages<'a> {
435 let reference = match self.def { 412 let reference = match self.def {
436 Definition::Field(_) if &field == self.def => FileReference { 413 Definition::Field(_) if &field == self.def => FileReference {
437 range, 414 range,
438 name: NameKind::NameRef, 415 name: NameLike::NameRef(name_ref.clone()),
439 access: reference_access(&field, &name_ref), 416 access: reference_access(&field, &name_ref),
440 }, 417 },
441 Definition::Local(l) if &local == l => FileReference { 418 Definition::Local(l) if &local == l => FileReference {
442 range, 419 range,
443 name: NameKind::NameRef, 420 name: NameLike::NameRef(name_ref.clone()),
444 access: reference_access(&Definition::Local(local), &name_ref), 421 access: reference_access(&Definition::Local(local), &name_ref),
445 }, 422 },
446 _ => return false, // not a usage 423 _ => return false, // not a usage
@@ -464,7 +441,7 @@ impl<'a> FindUsages<'a> {
464 let FileRange { file_id, range } = self.sema.original_range(name.syntax()); 441 let FileRange { file_id, range } = self.sema.original_range(name.syntax());
465 let reference = FileReference { 442 let reference = FileReference {
466 range, 443 range,
467 name: NameKind::Name, 444 name: NameLike::Name(name.clone()),
468 // FIXME: mutable patterns should have `Write` access 445 // FIXME: mutable patterns should have `Write` access
469 access: Some(ReferenceAccess::Read), 446 access: Some(ReferenceAccess::Read),
470 }; 447 };