mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-01 07:48:45 +00:00
fix: allow more kinds of if let patterns in guarded return assist
This commit is contained in:
parent
0840038f02
commit
146a7cc490
1 changed files with 57 additions and 19 deletions
|
@ -51,22 +51,7 @@ pub(crate) fn convert_to_guarded_return(acc: &mut Assists, ctx: &AssistContext<'
|
||||||
// Check if there is an IfLet that we can handle.
|
// Check if there is an IfLet that we can handle.
|
||||||
let (if_let_pat, cond_expr) = if is_pattern_cond(cond.clone()) {
|
let (if_let_pat, cond_expr) = if is_pattern_cond(cond.clone()) {
|
||||||
let let_ = single_let(cond)?;
|
let let_ = single_let(cond)?;
|
||||||
match let_.pat() {
|
(Some(let_.pat()?), let_.expr()?)
|
||||||
Some(ast::Pat::TupleStructPat(pat)) if pat.fields().count() == 1 => {
|
|
||||||
let path = pat.path()?;
|
|
||||||
if path.qualifier().is_some() {
|
|
||||||
return None;
|
|
||||||
}
|
|
||||||
|
|
||||||
let bound_ident = pat.fields().next()?;
|
|
||||||
if !ast::IdentPat::can_cast(bound_ident.syntax().kind()) {
|
|
||||||
return None;
|
|
||||||
}
|
|
||||||
|
|
||||||
(Some((path, bound_ident)), let_.expr()?)
|
|
||||||
}
|
|
||||||
_ => return None, // Unsupported IfLet.
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
(None, cond)
|
(None, cond)
|
||||||
};
|
};
|
||||||
|
@ -136,11 +121,10 @@ pub(crate) fn convert_to_guarded_return(acc: &mut Assists, ctx: &AssistContext<'
|
||||||
};
|
};
|
||||||
new_expr.syntax().clone_for_update()
|
new_expr.syntax().clone_for_update()
|
||||||
}
|
}
|
||||||
Some((path, bound_ident)) => {
|
Some(pat) => {
|
||||||
// If-let.
|
// If-let.
|
||||||
let pat = make::tuple_struct_pat(path, once(bound_ident));
|
|
||||||
let let_else_stmt = make::let_else_stmt(
|
let let_else_stmt = make::let_else_stmt(
|
||||||
pat.into(),
|
pat,
|
||||||
None,
|
None,
|
||||||
cond_expr,
|
cond_expr,
|
||||||
ast::make::tail_only_block_expr(early_expression),
|
ast::make::tail_only_block_expr(early_expression),
|
||||||
|
@ -442,6 +426,60 @@ fn main() {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn convert_arbitrary_if_let_patterns() {
|
||||||
|
check_assist(
|
||||||
|
convert_to_guarded_return,
|
||||||
|
r#"
|
||||||
|
fn main() {
|
||||||
|
$0if let None = Some(92) {
|
||||||
|
foo();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
"#,
|
||||||
|
r#"
|
||||||
|
fn main() {
|
||||||
|
let None = Some(92) else { return };
|
||||||
|
foo();
|
||||||
|
}
|
||||||
|
"#,
|
||||||
|
);
|
||||||
|
|
||||||
|
check_assist(
|
||||||
|
convert_to_guarded_return,
|
||||||
|
r#"
|
||||||
|
fn main() {
|
||||||
|
$0if let [1, x] = [1, 92] {
|
||||||
|
foo(x);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
"#,
|
||||||
|
r#"
|
||||||
|
fn main() {
|
||||||
|
let [1, x] = [1, 92] else { return };
|
||||||
|
foo(x);
|
||||||
|
}
|
||||||
|
"#,
|
||||||
|
);
|
||||||
|
|
||||||
|
check_assist(
|
||||||
|
convert_to_guarded_return,
|
||||||
|
r#"
|
||||||
|
fn main() {
|
||||||
|
$0if let (Some(x), None) = (Some(92), None) {
|
||||||
|
foo(x);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
"#,
|
||||||
|
r#"
|
||||||
|
fn main() {
|
||||||
|
let (Some(x), None) = (Some(92), None) else { return };
|
||||||
|
foo(x);
|
||||||
|
}
|
||||||
|
"#,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn ignore_already_converted_if() {
|
fn ignore_already_converted_if() {
|
||||||
check_assist_not_applicable(
|
check_assist_not_applicable(
|
||||||
|
|
Loading…
Reference in a new issue