Remove unnecessary braces for extracted block expression

This commit is contained in:
Brandon 2021-04-20 23:41:17 -07:00
parent 15b34667c5
commit 1713f4c7cd

View file

@ -1227,10 +1227,20 @@ fn make_body(
FunctionBody::Expr(expr) => {
let expr = rewrite_body_segment(ctx, &fun.params, &handler, expr.syntax());
let expr = ast::Expr::cast(expr).unwrap();
match expr {
ast::Expr::BlockExpr(block) => {
// If the extracted expression is itself a block, there is no need to wrap it inside another block.
let block = block.dedent(old_indent);
// Recreate the block for formatting consistency with other extracted functions.
make::block_expr(block.statements(), block.tail_expr())
}
_ => {
let expr = expr.dedent(old_indent).indent(IndentLevel(1));
make::block_expr(Vec::new(), Some(expr))
}
}
}
FunctionBody::Span { parent, text_range } => {
let mut elements: Vec<_> = parent
.syntax()
@ -1544,7 +1554,7 @@ fn foo() {
}
fn $0fun_name() -> i32 {
{ 1 + 1 }
1 + 1
}"#,
);
}
@ -2526,7 +2536,6 @@ fn foo() {
}
fn $0fun_name(n: &mut i32) {
{
*n += *n;
bar(*n);
bar(*n+1);
@ -2536,7 +2545,6 @@ fn $0fun_name(n: &mut i32) {
let v = n;
*v = v.succ();
n.succ();
}
}",
);
}