Add completion for raw identifiers

This commit is contained in:
Blake Wyatt 2021-09-04 19:28:59 -04:00
parent c16e6474f9
commit 6c51ecad5b

View file

@ -16,7 +16,7 @@ use ide_db::{
helpers::{item_name, SnippetCap}, helpers::{item_name, SnippetCap},
RootDatabase, SymbolKind, RootDatabase, SymbolKind,
}; };
use syntax::TextRange; use syntax::{SyntaxKind, TextRange};
use crate::{ use crate::{
context::{PathCompletionContext, PathKind}, context::{PathCompletionContext, PathKind},
@ -91,14 +91,18 @@ pub(crate) fn render_field(
); );
item.set_relevance(CompletionRelevance { item.set_relevance(CompletionRelevance {
type_match: compute_type_match(ctx.completion, ty), type_match: compute_type_match(ctx.completion, ty),
exact_name_match: compute_exact_name_match(ctx.completion, &name), exact_name_match: compute_exact_name_match(ctx.completion, name.as_str()),
..CompletionRelevance::default() ..CompletionRelevance::default()
}); });
item.kind(SymbolKind::Field) item.kind(SymbolKind::Field)
.detail(ty.display(ctx.db()).to_string()) .detail(ty.display(ctx.db()).to_string())
.set_documentation(field.docs(ctx.db())) .set_documentation(field.docs(ctx.db()))
.set_deprecated(is_deprecated) .set_deprecated(is_deprecated)
.lookup_by(name); .lookup_by(name.as_str());
let is_keyword = SyntaxKind::from_keyword(name.as_str()).is_some();
if is_keyword && !matches!(name.as_str(), "self" | "crate" | "super" | "Self") {
item.insert_text(String::from("r#") + name.as_str());
}
if let Some(_ref_match) = compute_ref_match(ctx.completion, ty) { if let Some(_ref_match) = compute_ref_match(ctx.completion, ty) {
// FIXME // FIXME
// For now we don't properly calculate the edits for ref match // For now we don't properly calculate the edits for ref match
@ -821,6 +825,23 @@ struct ManualVtable { f: fn(u8, u8) }
fn main() -> ManualVtable { fn main() -> ManualVtable {
ManualVtable { f: foo } ManualVtable { f: foo }
} }
"#,
);
check_edit(
"type",
r#"
struct RawIdentTable { r#type: u32 }
fn main() -> RawIdentTable {
RawIdentTable { t$0: 42 }
}
"#,
r#"
struct RawIdentTable { r#type: u32 }
fn main() -> RawIdentTable {
RawIdentTable { r#type: 42 }
}
"#, "#,
); );
} }