From a4257eaa818a8bb75dd28b4f23ced0635837f60a Mon Sep 17 00:00:00 2001 From: Florian Verdonck Date: Thu, 25 Mar 2021 12:11:35 +0100 Subject: [PATCH] Only add parenthesis when operator length is equal or greater than indent size. Fixes #1532 (#1535) --- src/Fantomas.Tests/DynamicOperatorTests.fs | 32 ++++++++-- src/Fantomas.Tests/PatternMatchingTests.fs | 70 ++++++++++++++++++++++ src/Fantomas/CodePrinter.fs | 14 +++-- 3 files changed, 108 insertions(+), 8 deletions(-) diff --git a/src/Fantomas.Tests/DynamicOperatorTests.fs b/src/Fantomas.Tests/DynamicOperatorTests.fs index 51c1808e60..b32d90e25e 100644 --- a/src/Fantomas.Tests/DynamicOperatorTests.fs +++ b/src/Fantomas.Tests/DynamicOperatorTests.fs @@ -37,13 +37,37 @@ let ``keep () when dynamic operator inside boolean expr, #476`` () = equal """ let fieldColor (fieldNameX: string) = - (if f.errors?(fieldNameY) && f.touched?(fieldNameZ) then - IsDanger - else - NoColor) + if f.errors?(fieldNameY) && f.touched?(fieldNameZ) then + IsDanger + else + NoColor |> Input.Color """ +[] +let ``keep () when dynamic operator inside boolean expr, 2 spaces indent`` () = + formatSourceString + false + """let fieldColor (fieldNameX: string) = + if f.errors?(fieldNameY) && f.touched?(fieldNameZ) then + IsDanger + else + NoColor + |> Input.Color +""" + { config with IndentSize = 2 } + |> prepend newline + |> should + equal + """ +let fieldColor (fieldNameX: string) = + (if f.errors?(fieldNameY) && f.touched?(fieldNameZ) then + IsDanger + else + NoColor) + |> Input.Color +""" + [] let ``preserve back ticks from checked keyword, 937`` () = formatSourceString false "let toggle = unbox (e.target?``checked``)" config diff --git a/src/Fantomas.Tests/PatternMatchingTests.fs b/src/Fantomas.Tests/PatternMatchingTests.fs index 686536dd3b..f22679435e 100644 --- a/src/Fantomas.Tests/PatternMatchingTests.fs +++ b/src/Fantomas.Tests/PatternMatchingTests.fs @@ -1529,3 +1529,73 @@ let args = | LongPatIndentifierThree |] -> args | _ -> failwith "meh" """ + +[] +let ``match followed by pipe, 1532`` () = + formatSourceString + false + """ +match x with +| Foo f -> [] +| Bar x -> + "\n" + + columnHeadersText + + "\n" + + seprator + + "\n" + + itemsText +|> Some +""" + { config with IndentSize = 2 } + |> prepend newline + |> should + equal + """ +(match x with + | Foo f -> [] + | Bar x -> + "\n" + + columnHeadersText + + "\n" + + seprator + + "\n" + + itemsText) +|> Some +""" + +[] +let ``match followed by pipe, 4 spaces indent`` () = + formatSourceString + false + """ +match x with +| Foo f -> + "\n" + + columnHeadersText + + "\n" + + seprator + + "\n" + + itemsText +| Bar x -> + // comment + "" +|||> Some +""" + config + |> prepend newline + |> should + equal + """ +(match x with + | Foo f -> + "\n" + + columnHeadersText + + "\n" + + seprator + + "\n" + + itemsText + | Bar x -> + // comment + "") +|||> Some +""" diff --git a/src/Fantomas/CodePrinter.fs b/src/Fantomas/CodePrinter.fs index 9f34c0c787..9c4c5e1104 100644 --- a/src/Fantomas/CodePrinter.fs +++ b/src/Fantomas/CodePrinter.fs @@ -1731,8 +1731,12 @@ and genExpr astContext synExpr ctx = +> genExpr astContext e) let multilineExpr = + let operatorText = List.head es |> fun (s, _, _) -> s + (match e with - | SynExpr.IfThenElse _ -> autoParenthesisIfExpressionExceedsPageWidth (genExpr astContext e) + | SynExpr.IfThenElse _ + | SynExpr.Match _ when (ctx.Config.IndentSize <= operatorText.Length) -> + autoParenthesisIfExpressionExceedsPageWidth (genExpr astContext e) | _ -> genExpr astContext e) +> sepNln +> col @@ -2707,10 +2711,12 @@ and genMultilineInfixExpr astContext e1 operatorText operatorExpr e2 = if noBreakInfixOps.Contains(operatorText) then genOnelinerInfixExpr astContext e1 operatorText operatorExpr e2 else - let genE1 = + let genE1 (ctx: Context) = match e1 with - | SynExpr.IfThenElse _ -> autoParenthesisIfExpressionExceedsPageWidth (genExpr astContext e1) - | _ -> genExpr astContext e1 + | SynExpr.IfThenElse _ + | SynExpr.Match _ when (ctx.Config.IndentSize <= operatorText.Length) -> + autoParenthesisIfExpressionExceedsPageWidth (genExpr astContext e1) ctx + | _ -> genExpr astContext e1 ctx atCurrentColumn ( genE1