From 05e2a81dbc79a2f27e86d14790527e0d1c7cd569 Mon Sep 17 00:00:00 2001 From: Reese Williams Date: Wed, 7 Feb 2024 14:48:21 +0000 Subject: [PATCH 1/2] Don't double-indent breakables on the LHS of binaries --- librubyfmt/src/format.rs | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/librubyfmt/src/format.rs b/librubyfmt/src/format.rs index bcd48026..aa1b6a76 100644 --- a/librubyfmt/src/format.rs +++ b/librubyfmt/src/format.rs @@ -2506,11 +2506,14 @@ fn format_binary_inner(ps: &mut dyn ConcreteParserState, binary: Binary) { false, Box::new(|ps| { let op = binary.2; + let left_hand_side = *binary.1; - if let Expression::Binary(bin) = *binary.1 { + if let Expression::Binary(bin) = left_hand_side { format_binary_inner(ps, bin); } else { - format_expression(ps, *binary.1); + ps.dedent(Box::new(|ps| { + format_expression(ps, left_hand_side); + })); } let comparison_operators = vec![">", ">=", "===", "==", "<", "<=", "<=>", "!="]; From 378a1a3783a0f24b663f7eca2b976c5a7b2bd0dc Mon Sep 17 00:00:00 2001 From: Reese Williams Date: Wed, 7 Feb 2024 14:54:46 +0000 Subject: [PATCH 2/2] Fixtures --- fixtures/small/binary_operators_actual.rb | 14 ++++++++++++++ fixtures/small/binary_operators_expected.rb | 19 +++++++++++++++++++ 2 files changed, 33 insertions(+) diff --git a/fixtures/small/binary_operators_actual.rb b/fixtures/small/binary_operators_actual.rb index d8c2a61d..af242cfd 100644 --- a/fixtures/small/binary_operators_actual.rb +++ b/fixtures/small/binary_operators_actual.rb @@ -49,3 +49,17 @@ def bees! # Maybe there should be the same amount of bees equal_amount_of_bees? end + +MyClass.calculate_stuff / 2 +MyClass + .calculate_stuff / 2 +{1 => "", 2 => ""}.keys.sum / 5 +{1 => "", + 2 => ""}.keys.sum / 5 + +Foo.new( + a: Calculator.calculate_stuff + .map { _1.do_things! } + .sum + + 1000.to_f +) \ No newline at end of file diff --git a/fixtures/small/binary_operators_expected.rb b/fixtures/small/binary_operators_expected.rb index 94d6ccc8..8f63e12b 100644 --- a/fixtures/small/binary_operators_expected.rb +++ b/fixtures/small/binary_operators_expected.rb @@ -54,3 +54,22 @@ def bees! # Maybe there should be the same amount of bees equal_amount_of_bees? end + +MyClass.calculate_stuff / 2 +MyClass + .calculate_stuff / + 2 +{1 => "", 2 => ""}.keys.sum / 5 +{ + 1 => "", + 2 => "" +}.keys.sum / + 5 + +Foo.new( + a: Calculator + .calculate_stuff + .map { _1.do_things! } + .sum + + 1000.to_f +)