diff --git a/src/Fantomas.Core.Tests/Stroustrup/SynTypeDefnSimpleReprRecordTests.fs b/src/Fantomas.Core.Tests/Stroustrup/SynTypeDefnSimpleReprRecordTests.fs index f6fb4713cc..a3b9e8e528 100644 --- a/src/Fantomas.Core.Tests/Stroustrup/SynTypeDefnSimpleReprRecordTests.fs +++ b/src/Fantomas.Core.Tests/Stroustrup/SynTypeDefnSimpleReprRecordTests.fs @@ -294,3 +294,63 @@ type MangaDexAtHomeResponse = { |} } """ + +[] +let ``record interface declarations can break with Stroustrup enabled, 2787 `` () = + formatSourceString + false + """ +type IEvent = interface end + +type SomeEvent = + { Id: string + Name: string } + interface IEvent + +type UpdatedName = { PreviousName: string } +""" + { config with + NewlineBetweenTypeDefinitionAndMembers = false } + |> prepend newline + |> should + equal + """ +type IEvent = + interface + end + +type SomeEvent = { + Id: string + Name: string +} with + interface IEvent + +type UpdatedName = { PreviousName: string } +""" + +[] +let ``record member declarations can break with Stroustrup enabled, 2787 `` () = + formatSourceString + false + """ +type SomeEvent = + { Id: string + Name: string } + member x.BreakWithOtherStuffAs well = () + +type UpdatedName = { PreviousName: string } +""" + { config with + NewlineBetweenTypeDefinitionAndMembers = false } + |> prepend newline + |> should + equal + """ +type SomeEvent = { + Id: string + Name: string +} with + member x.BreakWithOtherStuffAs well = () + +type UpdatedName = { PreviousName: string } +""" diff --git a/src/Fantomas.Core/CodePrinter.fs b/src/Fantomas.Core/CodePrinter.fs index 3aafbf5fd4..39c70aa259 100644 --- a/src/Fantomas.Core/CodePrinter.fs +++ b/src/Fantomas.Core/CodePrinter.fs @@ -3246,9 +3246,7 @@ let genTypeDefn (td: TypeDefn) = +> genSingleTextNode node.ClosingBrace let genMembers = - onlyIf hasMembers sepNln - +> sepNlnBetweenTypeAndMembers typeDefnNode - +> genMemberDefnList members + onlyIf hasMembers (sepNln +> sepNlnBetweenTypeAndMembers typeDefnNode +> genMemberDefnList members) let anyFieldHasXmlDoc = List.exists (fun (fieldNode: FieldNode) -> fieldNode.XmlDoc.IsSome) node.Fields @@ -3267,8 +3265,7 @@ let genTypeDefn (td: TypeDefn) = genAccessOpt node.Accessibility +> genRecordFields - +> onlyIf hasMembers (sepSpace +> withKw +> indent) - +> genMembers + +> onlyIf hasMembers (sepSpace +> withKw +> indent +> genMembers +> unindent) let cramped = sepNlnUnlessLastEventIsNewline