From 958d88d73fde551420084b94e1c48cb8986d6337 Mon Sep 17 00:00:00 2001 From: David Bar-On Date: Tue, 5 Jan 2021 19:40:47 +0200 Subject: [PATCH] Use rewrite_assign_rhs_with_comments by ControlFlow rewrite_pat_expr --- src/formatting/expr.rs | 60 +++++++----------------------------------- 1 file changed, 10 insertions(+), 50 deletions(-) diff --git a/src/formatting/expr.rs b/src/formatting/expr.rs index 75c165d15b5..472162e65a6 100644 --- a/src/formatting/expr.rs +++ b/src/formatting/expr.rs @@ -11,9 +11,8 @@ use crate::formatting::{ chains::rewrite_chain, closures, comment::{ - combine_strs_with_missing_comments, comment_style, contains_comment, - recover_comment_removed, rewrite_comment, rewrite_missing_comment, CharClasses, - FindUncommented, + combine_strs_with_missing_comments, contains_comment, recover_comment_removed, + rewrite_comment, rewrite_missing_comment, CharClasses, FindUncommented, }, lists::{ definitive_tactic, itemize_list, shape_for_tactic, struct_lit_formatting, struct_lit_shape, @@ -896,54 +895,15 @@ impl<'a> ControlFlow<'a> { .snippet_provider .span_after(self.span, self.connector.trim()); let comments_span = mk_sp(comments_lo, expr.span.lo()); - - let missing_comments = match rewrite_missing_comment(comments_span, cond_shape, context) - { - None => "".to_owned(), - Some(comment) if self.connector.is_empty() || comment.is_empty() => comment, - // Handle same-line block comments: - // if let Some(foo) = /*bar*/ baz { ... } - // if let Some(ref /*def*/ mut /*abc*/ state)... - Some(comment) - if !comment_style(&comment, false).is_line_comment() - && !comment.contains('\n') => - { - format!(" {}", comment) - } - // Handle sequence of multiple inline comments: - // if let Some(n) = - // // this is a test comment - // // with another - // foo { .... } - Some(_) => { - let newline = &cond_shape - .indent - .block_indent(context.config) - .to_string_with_newline(context.config); - let shape = pat_shape.block_indent(context.config.tab_spaces()); - let comment = format!( - "{}{}", - newline, - rewrite_missing_comment(comments_span, shape, context)?, - ); - let lhs = format!("{}{}{}{}", matcher, pat_string, self.connector, comment); - let orig_rhs = Some(format!("{}{}", newline, expr.rewrite(context, shape)?)); - let rhs = choose_rhs( - context, - expr, - cond_shape, - orig_rhs, - RhsTactics::Default, - true, - )?; - return Some(format!("{}{}", lhs, rhs)); - } - }; - let result = format!( - "{}{}{}{}", - matcher, pat_string, self.connector, missing_comments + return rewrite_assign_rhs_with_comments( + context, + &format!("{}{}{}", matcher, pat_string, self.connector), + expr, + cond_shape, + RhsTactics::Default, + comments_span, + true, ); - return rewrite_assign_rhs(context, result, expr, cond_shape); } let expr_rw = expr.rewrite(context, cond_shape);