fix: Disable ref_match for qualified paths as well

I.e. don't suggest `Foo::&foo()`.

CC #8058.
This commit is contained in:
Florian Diebold 2022-03-27 12:50:16 +02:00
parent 02dd3168ef
commit 9a427839fa
2 changed files with 41 additions and 4 deletions

View File

@ -1467,6 +1467,43 @@ fn foo(f: Foo) { let _: &u32 = f.b$0 }
);
}
#[test]
fn qualified_path_ref() {
// disabled right now because it doesn't render correctly, #8058
check_kinds(
r#"
struct S;
struct T;
impl T {
fn foo() -> S {}
}
fn bar(s: &S) {}
fn main() {
bar(T::$0);
}
"#,
&[CompletionItemKind::SymbolKind(SymbolKind::Function)],
expect![[r#"
[
CompletionItem {
label: "foo()",
source_range: 95..95,
delete: 95..95,
insert: "foo()$0",
kind: SymbolKind(
Function,
),
lookup: "foo",
detail: "fn() -> S",
},
]
"#]],
);
}
#[test]
fn generic_enum() {
check_relevance(

View File

@ -74,10 +74,10 @@ fn render(
});
if let Some(ref_match) = compute_ref_match(completion, &ret_type) {
// FIXME
// For now we don't properly calculate the edits for ref match
// completions on methods, so we've disabled them. See #8058.
if matches!(func_kind, FuncKind::Function) {
// FIXME For now we don't properly calculate the edits for ref match
// completions on methods or qualified paths, so we've disabled them.
// See #8058.
if matches!(func_kind, FuncKind::Function) && ctx.completion.path_qual().is_none() {
item.ref_match(ref_match);
}
}