11894: complete pattern args based on type name r=Veykril a=cameron1024

Addresses #11892 

Changes function argument completion to cover a case like this:
```rust
struct Foo { bar: i32 }

fn qux(Foo { bar }: Foo) {
  println!("{bar}");
}
```
When completing the function call for `qux`, instead of expanding to `qux(_)`, it will now expand to `qux(foo)` (based on the snake-cased version of the name of the ADT)

Non ADTs are unaffected


Co-authored-by: cameron <cameron.studdstreet@gmail.com>
Co-authored-by: cameron1024 <cameron.studdstreet@gmail.com>
This commit is contained in:
bors[bot] 2022-04-04 13:06:51 +00:00 committed by GitHub
commit f5c069c9d9
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -3,7 +3,7 @@
use hir::{db::HirDatabase, AsAssocItem, HirDisplay}; use hir::{db::HirDatabase, AsAssocItem, HirDisplay};
use ide_db::{SnippetCap, SymbolKind}; use ide_db::{SnippetCap, SymbolKind};
use itertools::Itertools; use itertools::Itertools;
use stdx::format_to; use stdx::{format_to, to_lower_snake_case};
use syntax::SmolStr; use syntax::SmolStr;
use crate::{ use crate::{
@ -135,7 +135,17 @@ pub(super) fn add_call_parens<'b>(
let ref_ = ref_of_param(ctx, text, param.ty()); let ref_ = ref_of_param(ctx, text, param.ty());
f(&format_args!("${{{}:{}{}}}", index + offset, ref_, text)) f(&format_args!("${{{}:{}{}}}", index + offset, ref_, text))
} }
None => f(&format_args!("${{{}:_}}", index + offset,)), None => {
let name = match param.ty().as_adt() {
None => "_".to_string(),
Some(adt) => adt
.name(ctx.db)
.as_text()
.map(|s| to_lower_snake_case(s.as_str()))
.unwrap_or_else(|| "_".to_string()),
};
f(&format_args!("${{{}:{}}}", index + offset, name))
}
} }
}); });
match self_param { match self_param {
@ -516,6 +526,39 @@ fn take_mutably(mut x: &i32) {}
fn main() { fn main() {
take_mutably(${1:x})$0 take_mutably(${1:x})$0
} }
"#,
);
}
#[test]
fn complete_pattern_args_with_type_name_if_adt() {
check_edit(
"qux",
r#"
struct Foo {
bar: i32
}
fn qux(Foo { bar }: Foo) {
println!("{}", bar);
}
fn main() {
qu$0
}
"#,
r#"
struct Foo {
bar: i32
}
fn qux(Foo { bar }: Foo) {
println!("{}", bar);
}
fn main() {
qux(${1:foo})$0
}
"#, "#,
); );
} }