fix: await insertion with try_expr during extract_function

This commit is contained in:
vi_mi 2021-10-03 08:26:19 +00:00
parent 60c5449120
commit 61643513b6
2 changed files with 72 additions and 4 deletions

View file

@ -1090,7 +1090,7 @@ fn make_call(ctx: &AssistContext, fun: &Function, indent: IndentLevel) -> String
let args = make::arg_list(fun.params.iter().map(|param| param.to_arg(ctx))); let args = make::arg_list(fun.params.iter().map(|param| param.to_arg(ctx)));
let name = fun.name.clone(); let name = fun.name.clone();
let call_expr = if fun.self_param.is_some() { let mut call_expr = if fun.self_param.is_some() {
let self_arg = make::expr_path(make::ext::ident_path("self")); let self_arg = make::expr_path(make::ext::ident_path("self"));
make::expr_method_call(self_arg, name, args) make::expr_method_call(self_arg, name, args)
} else { } else {
@ -1100,6 +1100,9 @@ fn make_call(ctx: &AssistContext, fun: &Function, indent: IndentLevel) -> String
let handler = FlowHandler::from_ret_ty(fun, &ret_ty); let handler = FlowHandler::from_ret_ty(fun, &ret_ty);
if fun.control_flow.is_async {
call_expr = make::expr_await(call_expr);
}
let expr = handler.make_call_expr(call_expr).indent(indent); let expr = handler.make_call_expr(call_expr).indent(indent);
let mut_modifier = |var: &OutlivedLocal| if var.mut_usage_outside_body { "mut " } else { "" }; let mut_modifier = |var: &OutlivedLocal| if var.mut_usage_outside_body { "mut " } else { "" };
@ -1119,10 +1122,8 @@ fn make_call(ctx: &AssistContext, fun: &Function, indent: IndentLevel) -> String
buf.push_str(") = "); buf.push_str(") = ");
} }
} }
format_to!(buf, "{}", expr); format_to!(buf, "{}", expr);
if fun.control_flow.is_async {
buf.push_str(".await");
}
let insert_comma = fun let insert_comma = fun
.body .body
.parent() .parent()
@ -3870,6 +3871,70 @@ async fn $0fun_name() {
async fn some_function() { async fn some_function() {
}
"#,
);
}
#[test]
fn extract_with_await_and_result_not_producing_match_expr() {
check_assist(
extract_function,
r#"
async fn foo() -> Result<(), ()> {
$0async {}.await;
Err(())?$0
}
"#,
r#"
async fn foo() -> Result<(), ()> {
fun_name().await?
}
async fn $0fun_name() -> _ {
async {}.await;
Err(())?
}
"#,
);
}
#[test]
fn extract_with_await_and_result_producing_match_expr() {
check_assist(
extract_function,
r#"
async fn foo() -> i32 {
loop {
let n = 1;$0
let k = async { 1 }.await;
if k == 42 {
break 3;
}
let m = k + 1;$0
let h = 1 + m;
}
}
"#,
r#"
async fn foo() -> i32 {
loop {
let n = 1;
let m = match fun_name().await {
Ok(value) => value,
Err(value) => break value,
};
let h = 1 + m;
}
}
async fn $0fun_name() -> Result<i32, i32> {
let k = async { 1 }.await;
if k == 42 {
return Err(3);
}
let m = k + 1;
Ok(m)
} }
"#, "#,
); );

View file

@ -299,6 +299,9 @@ pub fn expr_return(expr: Option<ast::Expr>) -> ast::Expr {
pub fn expr_try(expr: ast::Expr) -> ast::Expr { pub fn expr_try(expr: ast::Expr) -> ast::Expr {
expr_from_text(&format!("{}?", expr)) expr_from_text(&format!("{}?", expr))
} }
pub fn expr_await(expr: ast::Expr) -> ast::Expr {
expr_from_text(&format!("{}.await", expr))
}
pub fn expr_match(expr: ast::Expr, match_arm_list: ast::MatchArmList) -> ast::Expr { pub fn expr_match(expr: ast::Expr, match_arm_list: ast::MatchArmList) -> ast::Expr {
expr_from_text(&format!("match {} {}", expr, match_arm_list)) expr_from_text(&format!("match {} {}", expr, match_arm_list))
} }