Modernize unqualified reference completion tests

This commit is contained in:
Aleksey Kladov 2020-07-07 12:52:09 +02:00
parent 9b2847885d
commit 5b8a5bfb15
5 changed files with 407 additions and 1206 deletions

File diff suppressed because it is too large Load diff

View file

@ -196,22 +196,13 @@ impl<'a> CompletionContext<'a> {
// The range of the identifier that is being completed. // The range of the identifier that is being completed.
pub(crate) fn source_range(&self) -> TextRange { pub(crate) fn source_range(&self) -> TextRange {
// check kind of macro-expanded token, but use range of original token // check kind of macro-expanded token, but use range of original token
match self.token.kind() { if self.token.kind() == IDENT || self.token.kind().is_keyword() {
// workaroud when completion is triggered by trigger characters. mark::hit!(completes_if_prefix_is_keyword);
IDENT => self.original_token.text_range(), self.original_token.text_range()
_ => {
// If we haven't characters between keyword and our cursor we take the keyword start range to edit
if self.token.kind().is_keyword()
&& self.offset == self.original_token.text_range().end()
{
mark::hit!(completes_bindings_from_for_with_in_prefix);
TextRange::empty(self.original_token.text_range().start())
} else { } else {
TextRange::empty(self.offset) TextRange::empty(self.offset)
} }
} }
}
}
pub(crate) fn scope(&self) -> SemanticsScope<'_> { pub(crate) fn scope(&self) -> SemanticsScope<'_> {
self.sema.scope_at_offset(&self.token.parent(), self.offset) self.sema.scope_at_offset(&self.token.parent(), self.offset)

View file

@ -123,6 +123,7 @@ pub enum CompletionItemKind {
TypeParam, TypeParam,
Macro, Macro,
Attribute, Attribute,
UnresolvedReference,
} }
impl CompletionItemKind { impl CompletionItemKind {
@ -147,6 +148,7 @@ impl CompletionItemKind {
CompletionItemKind::Trait => "tt", CompletionItemKind::Trait => "tt",
CompletionItemKind::TypeAlias => "ta", CompletionItemKind::TypeAlias => "ta",
CompletionItemKind::TypeParam => "tp", CompletionItemKind::TypeParam => "tp",
CompletionItemKind::UnresolvedReference => "??",
} }
} }
} }

View file

@ -79,11 +79,10 @@ impl Completions {
return self.add_macro(ctx, Some(local_name), *mac); return self.add_macro(ctx, Some(local_name), *mac);
} }
ScopeDef::Unknown => { ScopeDef::Unknown => {
return self.add(CompletionItem::new( return self.add(
CompletionKind::Reference, CompletionItem::new(CompletionKind::Reference, ctx.source_range(), local_name)
ctx.source_range(), .kind(CompletionItemKind::UnresolvedReference),
local_name, );
));
} }
}; };

View file

@ -100,6 +100,7 @@ pub(crate) fn completion_item_kind(
CompletionItemKind::TypeParam => lsp_types::CompletionItemKind::TypeParameter, CompletionItemKind::TypeParam => lsp_types::CompletionItemKind::TypeParameter,
CompletionItemKind::Macro => lsp_types::CompletionItemKind::Method, CompletionItemKind::Macro => lsp_types::CompletionItemKind::Method,
CompletionItemKind::Attribute => lsp_types::CompletionItemKind::EnumMember, CompletionItemKind::Attribute => lsp_types::CompletionItemKind::EnumMember,
CompletionItemKind::UnresolvedReference => lsp_types::CompletionItemKind::Reference,
} }
} }