From: rainy-me Date: Fri, 3 Dec 2021 19:50:06 +0000 (+0900) Subject: fix: defer condition construction X-Git-Url: https://git.lizzy.rs/?a=commitdiff_plain;h=79b4e67b4ffdbdb58ad5b02398fd174e929609f8;p=rust.git fix: defer condition construction --- diff --git a/crates/ide_assists/src/handlers/convert_while_to_loop.rs b/crates/ide_assists/src/handlers/convert_while_to_loop.rs index a87d8d7166e..2bc64e77a38 100644 --- a/crates/ide_assists/src/handlers/convert_while_to_loop.rs +++ b/crates/ide_assists/src/handlers/convert_while_to_loop.rs @@ -42,11 +42,8 @@ pub(crate) fn convert_while_to_loop(acc: &mut Assists, ctx: &AssistContext) -> O let while_expr = while_kw.parent().and_then(ast::WhileExpr::cast)?; let while_body = while_expr.loop_body()?; let while_cond = while_expr.condition()?; + let while_cond_expr = while_cond.expr()?; - let if_cond = match while_cond.pat() { - Some(_) => while_expr.condition()?, - None => make::condition(invert_boolean_expression(while_cond.expr()?), None), - }; let target = while_expr.syntax().text_range(); acc.add( AssistId("convert_while_to_loop", AssistKind::RefactorRewrite), @@ -60,11 +57,12 @@ pub(crate) fn convert_while_to_loop(acc: &mut Assists, ctx: &AssistContext) -> O .indent(while_indent_level); let block_expr = match while_cond.pat() { Some(_) => { - let if_expr = make::expr_if(if_cond, while_body, Some(break_block.into())); + let if_expr = make::expr_if(while_cond, while_body, Some(break_block.into())); let stmts = once(make::expr_stmt(if_expr).into()); make::block_expr(stmts, None) } None => { + let if_cond = make::condition(invert_boolean_expression(while_cond_expr), None); let if_expr = make::expr_if(if_cond, break_block, None); let stmts = once(make::expr_stmt(if_expr).into()).chain(while_body.statements());