Merge pull request #20657 from A4-Tacks/fix-before-else-incomplete-let

Fix extra semicolon before else in let-stmt
This commit is contained in:
Laurențiu Nicola 2025-09-13 13:49:45 +00:00 committed by GitHub
commit 8192c6345f
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 51 additions and 1 deletions

View File

@ -269,6 +269,46 @@ fn main() {
"#,
);
check_edit(
"else if",
r#"
fn main() {
let x = if true {
()
} $0 else {};
}
"#,
r#"
fn main() {
let x = if true {
()
} else if $1 {
$0
} else {};
}
"#,
);
check_edit(
"else if",
r#"
fn main() {
let x = if true {
()
} $0 else if true {};
}
"#,
r#"
fn main() {
let x = if true {
()
} else if $1 {
$0
} else if true {};
}
"#,
);
check_edit(
"else",
r#"

View File

@ -970,6 +970,16 @@ fn classify_name_ref<'db>(
let after_incomplete_let = |node: SyntaxNode| {
prev_expr(node).and_then(|it| it.syntax().parent()).and_then(ast::LetStmt::cast)
};
let before_else_kw = |node: &SyntaxNode| {
node.parent()
.and_then(ast::ExprStmt::cast)
.filter(|stmt| stmt.semicolon_token().is_none())
.and_then(|stmt| non_trivia_sibling(stmt.syntax().clone().into(), Direction::Next))
.and_then(NodeOrToken::into_node)
.filter(|next| next.kind() == SyntaxKind::ERROR)
.and_then(|next| next.first_token())
.is_some_and(|token| token.kind() == SyntaxKind::ELSE_KW)
};
// We do not want to generate path completions when we are sandwiched between an item decl signature and its body.
// ex. trait Foo $0 {}
@ -1276,7 +1286,7 @@ fn classify_name_ref<'db>(
.parent()
.and_then(ast::LetStmt::cast)
.is_some_and(|it| it.semicolon_token().is_none())
|| after_incomplete_let && incomplete_expr_stmt.unwrap_or(true);
|| after_incomplete_let && incomplete_expr_stmt.unwrap_or(true) && !before_else_kw(it);
let in_value = it.parent().and_then(Either::<ast::LetStmt, ast::ArgList>::cast).is_some();
let impl_ = fetch_immediate_impl(sema, original_file, expr.syntax());