mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-28 12:55:11 +00:00
Merge #7235
7235: Postfix completions like ifl now works with references r=Veykril a=Maan2003 Closes #7230 Co-authored-by: Manmeet <manmeetmann2003@gmail.com> Co-authored-by: Manmeet Maan <manmeetmann2003@gmail.com>
This commit is contained in:
commit
8c33ffecc1
1 changed files with 25 additions and 1 deletions
|
@ -35,11 +35,14 @@ pub(crate) fn complete_postfix(acc: &mut Completions, ctx: &CompletionContext) {
|
||||||
None => return,
|
None => return,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
let ref_removed_ty =
|
||||||
|
std::iter::successors(Some(receiver_ty.clone()), |ty| ty.remove_ref()).last().unwrap();
|
||||||
|
|
||||||
let cap = match ctx.config.snippet_cap {
|
let cap = match ctx.config.snippet_cap {
|
||||||
Some(it) => it,
|
Some(it) => it,
|
||||||
None => return,
|
None => return,
|
||||||
};
|
};
|
||||||
let try_enum = TryEnum::from_ty(&ctx.sema, &receiver_ty);
|
let try_enum = TryEnum::from_ty(&ctx.sema, &ref_removed_ty);
|
||||||
if let Some(try_enum) = &try_enum {
|
if let Some(try_enum) = &try_enum {
|
||||||
match try_enum {
|
match try_enum {
|
||||||
TryEnum::Result => {
|
TryEnum::Result => {
|
||||||
|
@ -496,6 +499,27 @@ fn main() {
|
||||||
fn postfix_completion_for_references() {
|
fn postfix_completion_for_references() {
|
||||||
check_edit("dbg", r#"fn main() { &&42.$0 }"#, r#"fn main() { dbg!(&&42) }"#);
|
check_edit("dbg", r#"fn main() { &&42.$0 }"#, r#"fn main() { dbg!(&&42) }"#);
|
||||||
check_edit("refm", r#"fn main() { &&42.$0 }"#, r#"fn main() { &&&mut 42 }"#);
|
check_edit("refm", r#"fn main() { &&42.$0 }"#, r#"fn main() { &&&mut 42 }"#);
|
||||||
|
check_edit(
|
||||||
|
"ifl",
|
||||||
|
r#"
|
||||||
|
enum Option<T> { Some(T), None }
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
let bar = &Option::Some(true);
|
||||||
|
bar.$0
|
||||||
|
}
|
||||||
|
"#,
|
||||||
|
r#"
|
||||||
|
enum Option<T> { Some(T), None }
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
let bar = &Option::Some(true);
|
||||||
|
if let Some($1) = bar {
|
||||||
|
$0
|
||||||
|
}
|
||||||
|
}
|
||||||
|
"#,
|
||||||
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
|
Loading…
Reference in a new issue