mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-14 14:13:58 +00:00
Auto merge of #12851 - DorianListens:dscheidt/if-completion-match-guard, r=Veykril
fix: Don't add braces to 'if' completion in match guard position fixes #12823 Is this what you were thinking of here, `@Veykril` ? I haven't done any work on completions before, so I could definitely be misunderstanding the issue.
This commit is contained in:
commit
2be00623e4
4 changed files with 88 additions and 1 deletions
|
@ -21,6 +21,7 @@ pub(crate) fn complete_expr_path(
|
||||||
ref is_func_update,
|
ref is_func_update,
|
||||||
ref innermost_ret_ty,
|
ref innermost_ret_ty,
|
||||||
ref impl_,
|
ref impl_,
|
||||||
|
in_match_guard,
|
||||||
..
|
..
|
||||||
}: &ExprCtx,
|
}: &ExprCtx,
|
||||||
) {
|
) {
|
||||||
|
@ -195,7 +196,11 @@ pub(crate) fn complete_expr_path(
|
||||||
add_keyword("while", "while $1 {\n $0\n}");
|
add_keyword("while", "while $1 {\n $0\n}");
|
||||||
add_keyword("while let", "while let $1 = $2 {\n $0\n}");
|
add_keyword("while let", "while let $1 = $2 {\n $0\n}");
|
||||||
add_keyword("loop", "loop {\n $0\n}");
|
add_keyword("loop", "loop {\n $0\n}");
|
||||||
add_keyword("if", "if $1 {\n $0\n}");
|
if in_match_guard {
|
||||||
|
add_keyword("if", "if $0");
|
||||||
|
} else {
|
||||||
|
add_keyword("if", "if $1 {\n $0\n}");
|
||||||
|
}
|
||||||
add_keyword("if let", "if let $1 = $2 {\n $0\n}");
|
add_keyword("if let", "if let $1 = $2 {\n $0\n}");
|
||||||
add_keyword("for", "for $1 in $2 {\n $0\n}");
|
add_keyword("for", "for $1 in $2 {\n $0\n}");
|
||||||
add_keyword("true", "true");
|
add_keyword("true", "true");
|
||||||
|
|
|
@ -163,4 +163,75 @@ fn main() {
|
||||||
"#,
|
"#,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn if_completion_in_match_guard() {
|
||||||
|
check_edit(
|
||||||
|
"if",
|
||||||
|
r"
|
||||||
|
fn main() {
|
||||||
|
match () {
|
||||||
|
() $0
|
||||||
|
}
|
||||||
|
}
|
||||||
|
",
|
||||||
|
r"
|
||||||
|
fn main() {
|
||||||
|
match () {
|
||||||
|
() if $0
|
||||||
|
}
|
||||||
|
}
|
||||||
|
",
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn if_completion_in_match_arm_expr() {
|
||||||
|
check_edit(
|
||||||
|
"if",
|
||||||
|
r"
|
||||||
|
fn main() {
|
||||||
|
match () {
|
||||||
|
() => $0
|
||||||
|
}
|
||||||
|
}
|
||||||
|
",
|
||||||
|
r"
|
||||||
|
fn main() {
|
||||||
|
match () {
|
||||||
|
() => if $1 {
|
||||||
|
$0
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
",
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn if_completion_in_match_arm_expr_block() {
|
||||||
|
check_edit(
|
||||||
|
"if",
|
||||||
|
r"
|
||||||
|
fn main() {
|
||||||
|
match () {
|
||||||
|
() => {
|
||||||
|
$0
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
",
|
||||||
|
r"
|
||||||
|
fn main() {
|
||||||
|
match () {
|
||||||
|
() => {
|
||||||
|
if $1 {
|
||||||
|
$0
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
",
|
||||||
|
)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -138,6 +138,9 @@ pub(crate) struct ExprCtx {
|
||||||
pub(crate) self_param: Option<hir::SelfParam>,
|
pub(crate) self_param: Option<hir::SelfParam>,
|
||||||
pub(crate) innermost_ret_ty: Option<hir::Type>,
|
pub(crate) innermost_ret_ty: Option<hir::Type>,
|
||||||
pub(crate) impl_: Option<ast::Impl>,
|
pub(crate) impl_: Option<ast::Impl>,
|
||||||
|
/// Whether this expression occurs in match arm guard position: before the
|
||||||
|
/// fat arrow token
|
||||||
|
pub(crate) in_match_guard: bool,
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Original file ast nodes
|
/// Original file ast nodes
|
||||||
|
|
|
@ -763,6 +763,13 @@ impl<'a> CompletionContext<'a> {
|
||||||
.map_or(false, |it| it.semicolon_token().is_none());
|
.map_or(false, |it| it.semicolon_token().is_none());
|
||||||
let impl_ = fetch_immediate_impl(sema, original_file, expr.syntax());
|
let impl_ = fetch_immediate_impl(sema, original_file, expr.syntax());
|
||||||
|
|
||||||
|
let in_match_guard = match it.parent().and_then(ast::MatchArm::cast) {
|
||||||
|
Some(arm) => arm
|
||||||
|
.fat_arrow_token()
|
||||||
|
.map_or(true, |arrow| it.text_range().start() < arrow.text_range().start()),
|
||||||
|
None => false,
|
||||||
|
};
|
||||||
|
|
||||||
PathKind::Expr {
|
PathKind::Expr {
|
||||||
expr_ctx: ExprCtx {
|
expr_ctx: ExprCtx {
|
||||||
in_block_expr,
|
in_block_expr,
|
||||||
|
@ -775,6 +782,7 @@ impl<'a> CompletionContext<'a> {
|
||||||
self_param,
|
self_param,
|
||||||
incomplete_let,
|
incomplete_let,
|
||||||
impl_,
|
impl_,
|
||||||
|
in_match_guard,
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in a new issue