Skip to content

Commit

Permalink
Merge pull request rust-lang#2509 from topecongiro/issue-2493
Browse files Browse the repository at this point in the history
Overflow the last rhs of a binary expression
  • Loading branch information
nrc authored Mar 15, 2018
2 parents 65ce7bb + 822dd41 commit c416246
Show file tree
Hide file tree
Showing 3 changed files with 39 additions and 7 deletions.
16 changes: 9 additions & 7 deletions src/expr.rs
Original file line number Diff line number Diff line change
Expand Up @@ -369,13 +369,15 @@ where
.and_then(|s| s.sub_width(pp.suffix.len()))
.and_then(|rhs_shape| rhs.rewrite(context, rhs_shape));
if let Some(ref rhs_result) = rhs_orig_result {
// If the rhs looks like block expression, we allow it to stay on the same line
// with the lhs even if it is multi-lined.
let allow_same_line = rhs_result
.lines()
.next()
.map(|first_line| first_line.ends_with('{'))
.unwrap_or(false);
// If the length of the lhs is equal to or shorter than the tab width or
// the rhs looks like block expression, we put the rhs on the same
// line with the lhs even if the rhs is multi-lined.
let allow_same_line = lhs_result.len() <= context.config.tab_spaces()
|| rhs_result
.lines()
.next()
.map(|first_line| first_line.ends_with('{'))
.unwrap_or(false);
if !rhs_result.contains('\n') || allow_same_line {
let one_line_width = last_line_width(&lhs_result) + pp.infix.len()
+ first_line_width(rhs_result) + pp.suffix.len();
Expand Down
14 changes: 14 additions & 0 deletions tests/source/expr.rs
Original file line number Diff line number Diff line change
Expand Up @@ -370,3 +370,17 @@ fn newlines_between_list_like_expr() {
fn issue2178() {
Ok(result.iter().map(|item| ls_util::rls_to_location(item)).collect())
}

// #2493
impl Foo {
fn bar(&self) {
{
let x = match () {
() => {
let i;
i == self.install_config.storage.experimental_compressed_block_size as usize
}
};
}
}
}
16 changes: 16 additions & 0 deletions tests/target/expr.rs
Original file line number Diff line number Diff line change
Expand Up @@ -393,3 +393,19 @@ fn issue2178() {
.map(|item| ls_util::rls_to_location(item))
.collect())
}

// #2493
impl Foo {
fn bar(&self) {
{
let x = match () {
() => {
let i;
i == self.install_config
.storage
.experimental_compressed_block_size as usize
}
};
}
}
}

0 comments on commit c416246

Please sign in to comment.