diff --git a/src/Fantomas.Tests/PatternMatchingTests.fs b/src/Fantomas.Tests/PatternMatchingTests.fs index ed05a9f262..f0050737e2 100644 --- a/src/Fantomas.Tests/PatternMatchingTests.fs +++ b/src/Fantomas.Tests/PatternMatchingTests.fs @@ -2056,3 +2056,34 @@ match! | None -> false | Some balance -> someRetrievedBalance = balance """ + +[] +let ``vanity alignment used when using long case in match block, 1926`` () = + formatSourceString + false + """ +match foo with +| SomeVeryLongMatchCase(1234567890, 1234567890, 1234567890, 1234567890, 1234567890, 1234567890, 1234567890, 1234567890, 1234567890, 1234567890) -> + bar() +| _ -> () """ + config + |> prepend newline + |> should + equal + """ +match foo with +| SomeVeryLongMatchCase + ( + 1234567890, + 1234567890, + 1234567890, + 1234567890, + 1234567890, + 1234567890, + 1234567890, + 1234567890, + 1234567890, + 1234567890 + ) -> bar () +| _ -> () +""" diff --git a/src/Fantomas/CodePrinter.fs b/src/Fantomas/CodePrinter.fs index 814886234b..3ea7ac264d 100644 --- a/src/Fantomas/CodePrinter.fs +++ b/src/Fantomas/CodePrinter.fs @@ -4965,10 +4965,22 @@ and genPat astContext pat = | _ -> true | _ -> true - ifElse isParenNecessary sepOpenT sepSpace - +> genPat astContext p - +> enterNodeTokenByName pat.Range RPAREN - +> ifElse isParenNecessary sepCloseT sepNone + expressionFitsOnRestOfLine + (ifElse isParenNecessary sepOpenT sepSpace + +> genPat astContext p + +> enterNodeTokenByName pat.Range RPAREN + +> ifElse isParenNecessary sepCloseT sepNone) + + (ifElse + astContext.IsInsideMatchClausePattern + (ifElse isParenNecessary ((indent +> sepNln +> sepOpenT +> indent +> sepNln)) sepNone) + (ifElse isParenNecessary sepOpenT sepSpace) + +> genPat astContext p + +> enterNodeTokenByName pat.Range RPAREN + +> (ifElse + astContext.IsInsideMatchClausePattern + (ifElse isParenNecessary (unindent +> sepNln +> sepCloseT +> unindent) sepNone) + (ifElse isParenNecessary sepCloseT sepNone))) | PatTuple ps -> expressionFitsOnRestOfLine (col sepComma ps (genPat astContext))