11218: fix: Correct has_ref detection, avoiding duplicate &mut insertion on parameter completion r=Veykril a=weirane

The original code fails to detect there's a ref in scenarios such as `&mut s` and `& s` because `WHITESPACE` and `IDENT` got reversed.

Closes #11199.

Co-authored-by: Wang Ruochen <wrc@ruo-chen.wang>
This commit is contained in:
bors[bot] 2022-01-06 23:17:51 +00:00 committed by GitHub
commit 2fb6f5e46a
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 31 additions and 1 deletions

View File

@ -904,7 +904,7 @@ fn path_or_use_tree_qualifier(path: &ast::Path) -> Option<(ast::Path, bool)> {
fn has_ref(token: &SyntaxToken) -> bool { fn has_ref(token: &SyntaxToken) -> bool {
let mut token = token.clone(); let mut token = token.clone();
for skip in [WHITESPACE, IDENT, T![mut]] { for skip in [IDENT, WHITESPACE, T![mut]] {
if token.kind() == skip { if token.kind() == skip {
token = match token.prev_token() { token = match token.prev_token() {
Some(it) => it, Some(it) => it,
@ -1020,6 +1020,20 @@ fn bar(x: &u32) {}
r#" r#"
fn foo() { bar(&mut $0); } fn foo() { bar(&mut $0); }
fn bar(x: &mut u32) {} fn bar(x: &mut u32) {}
"#,
expect![[r#"ty: u32, name: x"#]],
);
check_expected_type_and_name(
r#"
fn foo() { bar(& c$0); }
fn bar(x: &u32) {}
"#,
expect![[r#"ty: u32, name: x"#]],
);
check_expected_type_and_name(
r#"
fn foo() { bar(&mut c$0); }
fn bar(x: &mut u32) {}
"#, "#,
expect![[r#"ty: u32, name: x"#]], expect![[r#"ty: u32, name: x"#]],
); );

View File

@ -1151,6 +1151,22 @@ fn main() {
fn foo() [] fn foo() []
"#]], "#]],
); );
check_relevance(
r#"
struct S;
fn foo(s: &mut S) {}
fn main() {
let mut ssss = S;
foo(&mut s$0);
}
"#,
expect![[r#"
lc ssss [type+local]
st S []
fn main() []
fn foo() []
"#]],
);
} }
#[test] #[test]