From 9ccf4371888c81416e0ecaf61fc278e3bbefd1b5 Mon Sep 17 00:00:00 2001 From: nojaf Date: Fri, 13 Sep 2024 09:55:26 +0200 Subject: [PATCH 01/20] Update FCS to 92754eb9b7076c29e19d3f6d619883b2b526c23f --- Directory.Build.props | 4 +- Directory.Packages.props | 4 +- build.fsx | 1 + global.json | 4 +- src/Fantomas.Benchmarks/packages.lock.json | 10 ++--- src/Fantomas.Client.Tests/packages.lock.json | 41 ++++++++--------- src/Fantomas.Client/packages.lock.json | 46 ++++++++++---------- src/Fantomas.Core.Tests/packages.lock.json | 21 ++++----- src/Fantomas.Core/packages.lock.json | 8 ++-- src/Fantomas.FCS/Fantomas.FCS.fsproj | 3 ++ src/Fantomas.FCS/packages.lock.json | 6 +-- src/Fantomas.Tests/packages.lock.json | 23 +++++----- src/Fantomas/packages.lock.json | 21 ++++----- 13 files changed, 102 insertions(+), 90 deletions(-) diff --git a/Directory.Build.props b/Directory.Build.props index 7c22db742..41e011872 100644 --- a/Directory.Build.props +++ b/Directory.Build.props @@ -40,12 +40,12 @@ Some common use cases include: true true - $(OtherFlags) --test:GraphBasedChecking --test:ParallelOptimization --test:ParallelIlxGen --strict-indentation+ + $(OtherFlags) --test:GraphBasedChecking --test:ParallelOptimization --test:ParallelIlxGen --strict-indentation+ --realsig+ - 836d4e0603442d6053c8d439993a022501cae494 + 92754eb9b7076c29e19d3f6d619883b2b526c23f diff --git a/Directory.Packages.props b/Directory.Packages.props index 12d2619ec..f11715b05 100644 --- a/Directory.Packages.props +++ b/Directory.Packages.props @@ -1,9 +1,10 @@ true + true - + @@ -18,6 +19,7 @@ + diff --git a/build.fsx b/build.fsx index bd18e4e44..4c4c24f4f 100644 --- a/build.fsx +++ b/build.fsx @@ -228,6 +228,7 @@ pipeline "Init" { run (fun _ -> [| "src/Compiler/FSComp.txt" "src/Compiler/FSStrings.resx" + "src/Compiler/Utilities/NullnessShims.fs" "src/Compiler/Utilities/Activity.fsi" "src/Compiler/Utilities/Activity.fs" "src/Compiler/Utilities/sformat.fsi" diff --git a/global.json b/global.json index 8d0a1c0ac..2c089ece3 100644 --- a/global.json +++ b/global.json @@ -1,6 +1,6 @@ { "sdk": { - "version": "8.0.300", - "rollForward": "latestMinor" + "version": "9.0.100-rc.1.24452.12", + "rollForward": "latestPatch" } } \ No newline at end of file diff --git a/src/Fantomas.Benchmarks/packages.lock.json b/src/Fantomas.Benchmarks/packages.lock.json index 9b5a34797..cbcc1672c 100644 --- a/src/Fantomas.Benchmarks/packages.lock.json +++ b/src/Fantomas.Benchmarks/packages.lock.json @@ -28,9 +28,9 @@ }, "FSharp.Core": { "type": "Direct", - "requested": "[6.0.1, )", - "resolved": "6.0.1", - "contentHash": "VrFAiW8dEEekk+0aqlbvMNZzDvYXmgWZwAt68AUBqaWK8RnoEVUNglj66bZzhs4/U63q0EfXlhcEKnH1sTYLjw==" + "requested": "[9.0.100-beta.24422.2, )", + "resolved": "9.0.100-beta.24422.2", + "contentHash": "NmzJmz7DS6h+kAW14ooG396DAr2xU8NbAj73RNZvQg+aNaLC0PLJYcvsQ8r6Hb0ZUZxKnjxTn3ROsQiSDSNaKg==" }, "G-Research.FSharp.Analyzers": { "type": "Direct", @@ -274,14 +274,14 @@ "fantomas.core": { "type": "Project", "dependencies": { - "FSharp.Core": "[6.0.1, )", + "FSharp.Core": "[9.0.100-beta.24422.2, )", "Fantomas.FCS": "[1.0.0, )" } }, "fantomas.fcs": { "type": "Project", "dependencies": { - "FSharp.Core": "[6.0.1, )", + "FSharp.Core": "[9.0.100-beta.24422.2, )", "System.Collections.Immutable": "[7.0.0, )", "System.Diagnostics.DiagnosticSource": "[7.0.0, )", "System.Memory": "[4.5.5, )", diff --git a/src/Fantomas.Client.Tests/packages.lock.json b/src/Fantomas.Client.Tests/packages.lock.json index 995df0067..d82dc6968 100644 --- a/src/Fantomas.Client.Tests/packages.lock.json +++ b/src/Fantomas.Client.Tests/packages.lock.json @@ -16,9 +16,9 @@ }, "FSharp.Core": { "type": "Direct", - "requested": "[6.0.1, )", - "resolved": "6.0.1", - "contentHash": "VrFAiW8dEEekk+0aqlbvMNZzDvYXmgWZwAt68AUBqaWK8RnoEVUNglj66bZzhs4/U63q0EfXlhcEKnH1sTYLjw==" + "requested": "[9.0.100-beta.24422.2, )", + "resolved": "9.0.100-beta.24422.2", + "contentHash": "NmzJmz7DS6h+kAW14ooG396DAr2xU8NbAj73RNZvQg+aNaLC0PLJYcvsQ8r6Hb0ZUZxKnjxTn3ROsQiSDSNaKg==" }, "G-Research.FSharp.Analyzers": { "type": "Direct", @@ -91,8 +91,8 @@ }, "Microsoft.NETCore.Targets": { "type": "Transitive", - "resolved": "1.1.0", - "contentHash": "aOZA3BWfz9RXjpzt0sRJJMjAscAUm3Hoa4UWAfceV9UTYxgwZ1lZt5nO2myFf+/jetYQo4uTP7zS8sJY67BBxg==" + "resolved": "1.1.3", + "contentHash": "3Wrmi0kJDzClwAC+iBdUBpEKmEle8FQNsCs77fkiOIw/9oYA07bL1EZNX0kQ2OMN3xpwvl0vAtOCYY3ndDNlhQ==" }, "Microsoft.TestPlatform.ObjectModel": { "type": "Transitive", @@ -166,11 +166,6 @@ "System.Runtime.CompilerServices.Unsafe": "4.7.1" } }, - "Newtonsoft.Json": { - "type": "Transitive", - "resolved": "13.0.1", - "contentHash": "ppPFpBcvxdsfUonNcvITKqLl3bqxWbDCZIzDWHzjpdAHRFfZe0Dw9HmA0+za13IdyrgJwpkDTDA9fHaxOrt20A==" - }, "NuGet.Frameworks": { "type": "Transitive", "resolved": "6.5.0", @@ -765,6 +760,12 @@ "StreamJsonRpc": "[2.8.28, )" } }, + "Newtonsoft.Json": { + "type": "CentralTransitive", + "requested": "[13.0.3, )", + "resolved": "13.0.3", + "contentHash": "HrC5BXdl00IP9zeV+0Z848QWPAoCr9P3bDEZguI+gkLcBKAOxix/tLEAAHC+UvDNPv4a2d18lOReHMOagPa+zQ==" + }, "SemanticVersioning": { "type": "CentralTransitive", "requested": "[2.0.2, )", @@ -796,29 +797,29 @@ "System.Collections.Immutable": { "type": "CentralTransitive", "requested": "[7.0.0, )", - "resolved": "5.0.0", - "contentHash": "FXkLXiK0sVVewcso0imKQoOxjoPAj42R8HtjjbSjVPAzwDfzoyoznWxgA3c38LDbN9SJux1xXoXYAhz98j7r2g==" + "resolved": "7.0.0", + "contentHash": "dQPcs0U1IKnBdRDBkrCTi1FoajSTBzLcVTpjO4MBCMC7f4pDOIPzgBoX8JjG7X6uZRJ8EBxsi8+DR1JuwjnzOQ==" }, "System.Diagnostics.DiagnosticSource": { "type": "CentralTransitive", "requested": "[7.0.0, )", - "resolved": "5.0.1", - "contentHash": "uXQEYqav2V3zP6OwkOKtLv+qIi6z3m1hsGyKwXX7ZA7htT4shoVccGxnJ9kVRFPNAsi1ArZTq2oh7WOto6GbkQ==" + "resolved": "7.0.0", + "contentHash": "9W0ewWDuAyDqS2PigdTxk6jDKonfgscY/hP8hm7VpxYhNHZHKvZTdRckberlFk3VnCmr3xBUyMBut12Q+T2aOw==" }, "System.Memory": { "type": "CentralTransitive", "requested": "[4.5.5, )", - "resolved": "4.5.4", - "contentHash": "1MbJTHS1lZ4bS4FmsJjnuGJOu88ZzTT2rLvrhW7Ygic+pC0NWA+3hgAen0HRdsocuQXCkUTdFn9yHJJhsijDXw==" + "resolved": "4.5.5", + "contentHash": "XIWiDvKPXaTveaB7HVganDlOCRoj03l+jrwNvcge/t8vhGYKvqV+dMv6G4SAX2NoNmN0wZfVPTAlFwZcZvVOUw==" }, "System.Runtime": { "type": "CentralTransitive", "requested": "[4.3.1, )", - "resolved": "4.3.0", - "contentHash": "JufQi0vPQ0xGnAczR13AUFglDyVYt4Kqnz1AZaiKZ5+GICq0/1MH/mO/eAJHt/mHW1zjKBJd7kV26SrxddAhiw==", + "resolved": "4.3.1", + "contentHash": "abhfv1dTK6NXOmu4bgHIONxHyEqFjW8HwXPmpY9gmll+ix9UNo4XDcmzJn6oLooftxNssVHdJC1pGT9jkSynQg==", "dependencies": { - "Microsoft.NETCore.Platforms": "1.1.0", - "Microsoft.NETCore.Targets": "1.1.0" + "Microsoft.NETCore.Platforms": "1.1.1", + "Microsoft.NETCore.Targets": "1.1.3" } } } diff --git a/src/Fantomas.Client/packages.lock.json b/src/Fantomas.Client/packages.lock.json index 484f33f58..57fc70151 100644 --- a/src/Fantomas.Client/packages.lock.json +++ b/src/Fantomas.Client/packages.lock.json @@ -121,8 +121,8 @@ }, "Microsoft.NETCore.Targets": { "type": "Transitive", - "resolved": "1.1.0", - "contentHash": "aOZA3BWfz9RXjpzt0sRJJMjAscAUm3Hoa4UWAfceV9UTYxgwZ1lZt5nO2myFf+/jetYQo4uTP7zS8sJY67BBxg==" + "resolved": "1.1.3", + "contentHash": "3Wrmi0kJDzClwAC+iBdUBpEKmEle8FQNsCs77fkiOIw/9oYA07bL1EZNX0kQ2OMN3xpwvl0vAtOCYY3ndDNlhQ==" }, "Microsoft.SourceLink.AzureRepos.Git": { "type": "Transitive", @@ -221,11 +221,6 @@ "System.Runtime.CompilerServices.Unsafe": "4.7.1" } }, - "Newtonsoft.Json": { - "type": "Transitive", - "resolved": "12.0.2", - "contentHash": "rTK0s2EKlfHsQsH6Yx2smvcTCeyoDNgCW7FEYyV01drPlh2T243PR2DiDXqtC5N4GDm4Ma/lkxfW5a/4793vbA==" - }, "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl": { "type": "Transitive", "resolved": "4.3.2", @@ -584,8 +579,8 @@ }, "System.Runtime.CompilerServices.Unsafe": { "type": "Transitive", - "resolved": "5.0.0", - "contentHash": "ZD9TMpsmYJLrxbbmdvhwt9YEgG5WntEnZ/d1eH8JBX9LBp+Ju8BSBhUGbZMNVHHomWo2KVImJhTDl2hIgw/6MA==" + "resolved": "6.0.0", + "contentHash": "/iUeP3tq1S0XdNNoMz5C9twLSrM/TH+qElHkXWaPvuNOt+99G75NrV0OS2EqHx5wMN7popYjpc8oTjC1y16DLg==" }, "System.Runtime.Extensions": { "type": "Transitive", @@ -830,30 +825,37 @@ "System.Runtime.CompilerServices.Unsafe": "4.5.3" } }, + "Newtonsoft.Json": { + "type": "CentralTransitive", + "requested": "[13.0.3, )", + "resolved": "13.0.3", + "contentHash": "HrC5BXdl00IP9zeV+0Z848QWPAoCr9P3bDEZguI+gkLcBKAOxix/tLEAAHC+UvDNPv4a2d18lOReHMOagPa+zQ==" + }, "System.Collections.Immutable": { "type": "CentralTransitive", "requested": "[7.0.0, )", - "resolved": "5.0.0", - "contentHash": "FXkLXiK0sVVewcso0imKQoOxjoPAj42R8HtjjbSjVPAzwDfzoyoznWxgA3c38LDbN9SJux1xXoXYAhz98j7r2g==", + "resolved": "7.0.0", + "contentHash": "dQPcs0U1IKnBdRDBkrCTi1FoajSTBzLcVTpjO4MBCMC7f4pDOIPzgBoX8JjG7X6uZRJ8EBxsi8+DR1JuwjnzOQ==", "dependencies": { - "System.Memory": "4.5.4" + "System.Memory": "4.5.5", + "System.Runtime.CompilerServices.Unsafe": "6.0.0" } }, "System.Diagnostics.DiagnosticSource": { "type": "CentralTransitive", "requested": "[7.0.0, )", - "resolved": "5.0.1", - "contentHash": "uXQEYqav2V3zP6OwkOKtLv+qIi6z3m1hsGyKwXX7ZA7htT4shoVccGxnJ9kVRFPNAsi1ArZTq2oh7WOto6GbkQ==", + "resolved": "7.0.0", + "contentHash": "9W0ewWDuAyDqS2PigdTxk6jDKonfgscY/hP8hm7VpxYhNHZHKvZTdRckberlFk3VnCmr3xBUyMBut12Q+T2aOw==", "dependencies": { - "System.Memory": "4.5.4", - "System.Runtime.CompilerServices.Unsafe": "5.0.0" + "System.Memory": "4.5.5", + "System.Runtime.CompilerServices.Unsafe": "6.0.0" } }, "System.Memory": { "type": "CentralTransitive", "requested": "[4.5.5, )", - "resolved": "4.5.4", - "contentHash": "1MbJTHS1lZ4bS4FmsJjnuGJOu88ZzTT2rLvrhW7Ygic+pC0NWA+3hgAen0HRdsocuQXCkUTdFn9yHJJhsijDXw==", + "resolved": "4.5.5", + "contentHash": "XIWiDvKPXaTveaB7HVganDlOCRoj03l+jrwNvcge/t8vhGYKvqV+dMv6G4SAX2NoNmN0wZfVPTAlFwZcZvVOUw==", "dependencies": { "System.Buffers": "4.5.1", "System.Numerics.Vectors": "4.4.0", @@ -863,11 +865,11 @@ "System.Runtime": { "type": "CentralTransitive", "requested": "[4.3.1, )", - "resolved": "4.3.0", - "contentHash": "JufQi0vPQ0xGnAczR13AUFglDyVYt4Kqnz1AZaiKZ5+GICq0/1MH/mO/eAJHt/mHW1zjKBJd7kV26SrxddAhiw==", + "resolved": "4.3.1", + "contentHash": "abhfv1dTK6NXOmu4bgHIONxHyEqFjW8HwXPmpY9gmll+ix9UNo4XDcmzJn6oLooftxNssVHdJC1pGT9jkSynQg==", "dependencies": { - "Microsoft.NETCore.Platforms": "1.1.0", - "Microsoft.NETCore.Targets": "1.1.0" + "Microsoft.NETCore.Platforms": "1.1.1", + "Microsoft.NETCore.Targets": "1.1.3" } } } diff --git a/src/Fantomas.Core.Tests/packages.lock.json b/src/Fantomas.Core.Tests/packages.lock.json index 4a095303b..e6a25d337 100644 --- a/src/Fantomas.Core.Tests/packages.lock.json +++ b/src/Fantomas.Core.Tests/packages.lock.json @@ -19,9 +19,9 @@ }, "FSharp.Core": { "type": "Direct", - "requested": "[6.0.1, )", - "resolved": "6.0.1", - "contentHash": "VrFAiW8dEEekk+0aqlbvMNZzDvYXmgWZwAt68AUBqaWK8RnoEVUNglj66bZzhs4/U63q0EfXlhcEKnH1sTYLjw==" + "requested": "[9.0.100-beta.24422.2, )", + "resolved": "9.0.100-beta.24422.2", + "contentHash": "NmzJmz7DS6h+kAW14ooG396DAr2xU8NbAj73RNZvQg+aNaLC0PLJYcvsQ8r6Hb0ZUZxKnjxTn3ROsQiSDSNaKg==" }, "FsUnit": { "type": "Direct", @@ -109,11 +109,6 @@ "Newtonsoft.Json": "13.0.1" } }, - "Newtonsoft.Json": { - "type": "Transitive", - "resolved": "13.0.1", - "contentHash": "ppPFpBcvxdsfUonNcvITKqLl3bqxWbDCZIzDWHzjpdAHRFfZe0Dw9HmA0+za13IdyrgJwpkDTDA9fHaxOrt20A==" - }, "NuGet.Frameworks": { "type": "Transitive", "resolved": "6.5.0", @@ -149,20 +144,26 @@ "fantomas.core": { "type": "Project", "dependencies": { - "FSharp.Core": "[6.0.1, )", + "FSharp.Core": "[9.0.100-beta.24422.2, )", "Fantomas.FCS": "[1.0.0, )" } }, "fantomas.fcs": { "type": "Project", "dependencies": { - "FSharp.Core": "[6.0.1, )", + "FSharp.Core": "[9.0.100-beta.24422.2, )", "System.Collections.Immutable": "[7.0.0, )", "System.Diagnostics.DiagnosticSource": "[7.0.0, )", "System.Memory": "[4.5.5, )", "System.Runtime": "[4.3.1, )" } }, + "Newtonsoft.Json": { + "type": "CentralTransitive", + "requested": "[13.0.3, )", + "resolved": "13.0.3", + "contentHash": "HrC5BXdl00IP9zeV+0Z848QWPAoCr9P3bDEZguI+gkLcBKAOxix/tLEAAHC+UvDNPv4a2d18lOReHMOagPa+zQ==" + }, "System.Collections.Immutable": { "type": "CentralTransitive", "requested": "[7.0.0, )", diff --git a/src/Fantomas.Core/packages.lock.json b/src/Fantomas.Core/packages.lock.json index ed4ccc3fe..be2ca1511 100644 --- a/src/Fantomas.Core/packages.lock.json +++ b/src/Fantomas.Core/packages.lock.json @@ -22,9 +22,9 @@ }, "FSharp.Core": { "type": "Direct", - "requested": "[6.0.1, )", - "resolved": "6.0.1", - "contentHash": "VrFAiW8dEEekk+0aqlbvMNZzDvYXmgWZwAt68AUBqaWK8RnoEVUNglj66bZzhs4/U63q0EfXlhcEKnH1sTYLjw==" + "requested": "[9.0.100-beta.24422.2, )", + "resolved": "9.0.100-beta.24422.2", + "contentHash": "NmzJmz7DS6h+kAW14ooG396DAr2xU8NbAj73RNZvQg+aNaLC0PLJYcvsQ8r6Hb0ZUZxKnjxTn3ROsQiSDSNaKg==" }, "G-Research.FSharp.Analyzers": { "type": "Direct", @@ -127,7 +127,7 @@ "fantomas.fcs": { "type": "Project", "dependencies": { - "FSharp.Core": "[6.0.1, )", + "FSharp.Core": "[9.0.100-beta.24422.2, )", "System.Collections.Immutable": "[7.0.0, )", "System.Diagnostics.DiagnosticSource": "[7.0.0, )", "System.Memory": "[4.5.5, )", diff --git a/src/Fantomas.FCS/Fantomas.FCS.fsproj b/src/Fantomas.FCS/Fantomas.FCS.fsproj index 0b8e460ff..00fa651db 100644 --- a/src/Fantomas.FCS/Fantomas.FCS.fsproj +++ b/src/Fantomas.FCS/Fantomas.FCS.fsproj @@ -23,6 +23,9 @@ FSStrings.resx FSStrings.resources + + Utilities\NullnessShims.fs + Utilities\Activity.fsi diff --git a/src/Fantomas.FCS/packages.lock.json b/src/Fantomas.FCS/packages.lock.json index f73abbc81..b5823fad7 100644 --- a/src/Fantomas.FCS/packages.lock.json +++ b/src/Fantomas.FCS/packages.lock.json @@ -22,9 +22,9 @@ }, "FSharp.Core": { "type": "Direct", - "requested": "[6.0.1, )", - "resolved": "6.0.1", - "contentHash": "VrFAiW8dEEekk+0aqlbvMNZzDvYXmgWZwAt68AUBqaWK8RnoEVUNglj66bZzhs4/U63q0EfXlhcEKnH1sTYLjw==" + "requested": "[9.0.100-beta.24422.2, )", + "resolved": "9.0.100-beta.24422.2", + "contentHash": "NmzJmz7DS6h+kAW14ooG396DAr2xU8NbAj73RNZvQg+aNaLC0PLJYcvsQ8r6Hb0ZUZxKnjxTn3ROsQiSDSNaKg==" }, "FsLexYacc": { "type": "Direct", diff --git a/src/Fantomas.Tests/packages.lock.json b/src/Fantomas.Tests/packages.lock.json index 781cd7336..70f7fa48f 100644 --- a/src/Fantomas.Tests/packages.lock.json +++ b/src/Fantomas.Tests/packages.lock.json @@ -19,9 +19,9 @@ }, "FSharp.Core": { "type": "Direct", - "requested": "[6.0.1, )", - "resolved": "6.0.1", - "contentHash": "VrFAiW8dEEekk+0aqlbvMNZzDvYXmgWZwAt68AUBqaWK8RnoEVUNglj66bZzhs4/U63q0EfXlhcEKnH1sTYLjw==" + "requested": "[9.0.100-beta.24422.2, )", + "resolved": "9.0.100-beta.24422.2", + "contentHash": "NmzJmz7DS6h+kAW14ooG396DAr2xU8NbAj73RNZvQg+aNaLC0PLJYcvsQ8r6Hb0ZUZxKnjxTn3ROsQiSDSNaKg==" }, "FsUnit": { "type": "Direct", @@ -196,11 +196,6 @@ "System.Runtime.CompilerServices.Unsafe": "4.7.1" } }, - "Newtonsoft.Json": { - "type": "Transitive", - "resolved": "13.0.1", - "contentHash": "ppPFpBcvxdsfUonNcvITKqLl3bqxWbDCZIzDWHzjpdAHRFfZe0Dw9HmA0+za13IdyrgJwpkDTDA9fHaxOrt20A==" - }, "NuGet.Frameworks": { "type": "Transitive", "resolved": "6.5.0", @@ -826,7 +821,7 @@ "type": "Project", "dependencies": { "Argu": "[6.2.4, )", - "FSharp.Core": "[6.0.1, )", + "FSharp.Core": "[9.0.100-beta.24422.2, )", "Fantomas.Client": "[1.0.0, )", "Fantomas.Core": "[1.0.0, )", "Ignore": "[0.1.50, )", @@ -851,14 +846,14 @@ "fantomas.core": { "type": "Project", "dependencies": { - "FSharp.Core": "[6.0.1, )", + "FSharp.Core": "[9.0.100-beta.24422.2, )", "Fantomas.FCS": "[1.0.0, )" } }, "fantomas.fcs": { "type": "Project", "dependencies": { - "FSharp.Core": "[6.0.1, )", + "FSharp.Core": "[9.0.100-beta.24422.2, )", "System.Collections.Immutable": "[7.0.0, )", "System.Diagnostics.DiagnosticSource": "[7.0.0, )", "System.Memory": "[4.5.5, )", @@ -887,6 +882,12 @@ "resolved": "0.1.50", "contentHash": "nr7/KaY5KP9QvCEf478w1k9Yz+dXQZKLEAsjfhIjuneScmyLvMKoItPL6OfkNODeCrINtHEBt8A7q7yETS1PQQ==" }, + "Newtonsoft.Json": { + "type": "CentralTransitive", + "requested": "[13.0.3, )", + "resolved": "13.0.3", + "contentHash": "HrC5BXdl00IP9zeV+0Z848QWPAoCr9P3bDEZguI+gkLcBKAOxix/tLEAAHC+UvDNPv4a2d18lOReHMOagPa+zQ==" + }, "SemanticVersioning": { "type": "CentralTransitive", "requested": "[2.0.2, )", diff --git a/src/Fantomas/packages.lock.json b/src/Fantomas/packages.lock.json index 5a219fa80..8cf056104 100644 --- a/src/Fantomas/packages.lock.json +++ b/src/Fantomas/packages.lock.json @@ -38,9 +38,9 @@ }, "FSharp.Core": { "type": "Direct", - "requested": "[6.0.1, )", - "resolved": "6.0.1", - "contentHash": "VrFAiW8dEEekk+0aqlbvMNZzDvYXmgWZwAt68AUBqaWK8RnoEVUNglj66bZzhs4/U63q0EfXlhcEKnH1sTYLjw==" + "requested": "[9.0.100-beta.24422.2, )", + "resolved": "9.0.100-beta.24422.2", + "contentHash": "NmzJmz7DS6h+kAW14ooG396DAr2xU8NbAj73RNZvQg+aNaLC0PLJYcvsQ8r6Hb0ZUZxKnjxTn3ROsQiSDSNaKg==" }, "G-Research.FSharp.Analyzers": { "type": "Direct", @@ -285,11 +285,6 @@ "System.Runtime.CompilerServices.Unsafe": "4.7.1" } }, - "Newtonsoft.Json": { - "type": "Transitive", - "resolved": "12.0.2", - "contentHash": "rTK0s2EKlfHsQsH6Yx2smvcTCeyoDNgCW7FEYyV01drPlh2T243PR2DiDXqtC5N4GDm4Ma/lkxfW5a/4793vbA==" - }, "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl": { "type": "Transitive", "resolved": "4.3.2", @@ -903,20 +898,26 @@ "fantomas.core": { "type": "Project", "dependencies": { - "FSharp.Core": "[6.0.1, )", + "FSharp.Core": "[9.0.100-beta.24422.2, )", "Fantomas.FCS": "[1.0.0, )" } }, "fantomas.fcs": { "type": "Project", "dependencies": { - "FSharp.Core": "[6.0.1, )", + "FSharp.Core": "[9.0.100-beta.24422.2, )", "System.Collections.Immutable": "[7.0.0, )", "System.Diagnostics.DiagnosticSource": "[7.0.0, )", "System.Memory": "[4.5.5, )", "System.Runtime": "[4.3.1, )" } }, + "Newtonsoft.Json": { + "type": "CentralTransitive", + "requested": "[13.0.3, )", + "resolved": "13.0.3", + "contentHash": "HrC5BXdl00IP9zeV+0Z848QWPAoCr9P3bDEZguI+gkLcBKAOxix/tLEAAHC+UvDNPv4a2d18lOReHMOagPa+zQ==" + }, "SemanticVersioning": { "type": "CentralTransitive", "requested": "[2.0.2, )", From ec0ad230bcf39de7353752cf85e3b361b8fc7f6d Mon Sep 17 00:00:00 2001 From: nojaf Date: Fri, 13 Sep 2024 10:11:43 +0200 Subject: [PATCH 02/20] Allow solution to build --- .../Fantomas.Core.Tests.fsproj | 1 + src/Fantomas.Core.Tests/NullnessTests.fs | 21 +++++++++++++++++++ src/Fantomas.Core/ASTTransformer.fs | 10 +++++++-- src/Fantomas/EditorConfig.fs | 2 +- 4 files changed, 31 insertions(+), 3 deletions(-) create mode 100644 src/Fantomas.Core.Tests/NullnessTests.fs diff --git a/src/Fantomas.Core.Tests/Fantomas.Core.Tests.fsproj b/src/Fantomas.Core.Tests/Fantomas.Core.Tests.fsproj index 78718e432..dec7da75c 100644 --- a/src/Fantomas.Core.Tests/Fantomas.Core.Tests.fsproj +++ b/src/Fantomas.Core.Tests/Fantomas.Core.Tests.fsproj @@ -132,6 +132,7 @@ + diff --git a/src/Fantomas.Core.Tests/NullnessTests.fs b/src/Fantomas.Core.Tests/NullnessTests.fs new file mode 100644 index 000000000..288dd1edb --- /dev/null +++ b/src/Fantomas.Core.Tests/NullnessTests.fs @@ -0,0 +1,21 @@ +module Fantomas.Core.Tests.NullnessTests + +open NUnit.Framework +open FsUnit +open Fantomas.Core.Tests.TestHelpers + +[] +let ``abstract property`` () = + formatSourceString + """ +[] +type AbstractBase() = + abstract Property1 : string | null with get, set +""" + config + |> prepend newline + |> should + equal + """ + +""" diff --git a/src/Fantomas.Core/ASTTransformer.fs b/src/Fantomas.Core/ASTTransformer.fs index 5544c7022..3b667beb2 100644 --- a/src/Fantomas.Core/ASTTransformer.fs +++ b/src/Fantomas.Core/ASTTransformer.fs @@ -78,6 +78,10 @@ let mkSynAccess (vis: SynAccess option) = | Some(SynAccess.Private range) -> Some(stn "private" range) | Some(SynAccess.Public range) -> Some(stn "public" range) +let mkSynValSigAccess (vis: SynValSigAccess) = + // https://fsharp.github.io/fsharp-compiler-docs/reference/fsharp-compiler-syntax-synvalsigaccess.html + failwith "todo SynValSigAccess: %A" vis + let parseExpressionInSynBinding returnInfo expr = match returnInfo, expr with | Some(SynBindingReturnInfo(typeName = t1)), SynExpr.Typed(e, t2, _) when RangeHelpers.rangeEq t1.Range t2.Range -> @@ -2168,6 +2172,8 @@ let mkSynTypeConstraint (creationAide: CreationAide) (tc: SynTypeConstraint) : T TypeConstraintEnumOrDelegateNode(mkSynTypar tp, "delegate", List.map (mkType creationAide) ts, m) |> TypeConstraint.EnumOrDelegate | SynTypeConstraint.WhereSelfConstrained(t, _) -> mkType creationAide t |> TypeConstraint.WhereSelfConstrained + | SynTypeConstraint.WhereTyparNotSupportsNull(genericName, range) -> + failwithf "todo WhereTyparNotSupportsNull : %A" (genericName, range) // Arrow type is right-associative let rec (|TFuns|_|) = @@ -2845,7 +2851,7 @@ let mkMemberDefn (creationAide: CreationAide) (md: SynMemberDefn) = mkXmlDoc px, mkAttributes creationAide ats, mkSynLeadingKeyword lk, - mkSynAccess ao, + mkSynValSigAccess ao, mkIdent ident, Option.map (mkType creationAide) typeOpt, stn "=" mEq, @@ -3027,7 +3033,7 @@ let mkVal lk, Option.map (stn "inline") trivia.InlineKeyword, isMutable, - mkSynAccess ao, + mkSynValSigAccess ao, mkSynIdent synIdent, mkSynValTyparDecls creationAide (Some vtd), mkType creationAide t, diff --git a/src/Fantomas/EditorConfig.fs b/src/Fantomas/EditorConfig.fs index f362fe4ba..87af71998 100644 --- a/src/Fantomas/EditorConfig.fs +++ b/src/Fantomas/EditorConfig.fs @@ -16,7 +16,7 @@ module Reflection = DisplayName: string option Description: string option } - let inline getCustomAttribute<'t, 'v when 't :> Attribute and 't: null> + let inline getCustomAttribute<'t, 'v when 't :> Attribute and 't: null and 't: not struct> (projection: 't -> 'v) (property: PropertyInfo) : 'v option = From 3116d6938e7e65982dc1e3ea496a3aadc26dbe1b Mon Sep 17 00:00:00 2001 From: nojaf Date: Fri, 13 Sep 2024 10:24:19 +0200 Subject: [PATCH 03/20] Add tests for new syntax --- .../AutoPropertiesTests.fs | 37 ++++++++ .../Fantomas.Core.Tests.fsproj | 1 + src/Fantomas.Core.Tests/NullnessTests.fs | 93 ++++++++++++++++++- 3 files changed, 127 insertions(+), 4 deletions(-) create mode 100644 src/Fantomas.Core.Tests/AutoPropertiesTests.fs diff --git a/src/Fantomas.Core.Tests/AutoPropertiesTests.fs b/src/Fantomas.Core.Tests/AutoPropertiesTests.fs new file mode 100644 index 000000000..acccf16f5 --- /dev/null +++ b/src/Fantomas.Core.Tests/AutoPropertiesTests.fs @@ -0,0 +1,37 @@ +module Fantomas.Core.Tests.AutoPropertiesTests + +open NUnit.Framework +open FsUnit +open Fantomas.Core.Tests.TestHelpers + +[] +let ``public get, private set`` () = + formatSourceString + """ +type X() = + member val Y: int = 7 with public get, private set +""" + config + |> prepend newline + |> should + equal + """ + +""" + +[] +let ``public get, private set in signature`` () = + formatSignatureString + """ +module A + +type X() = + member val internal Y: int = 7 with public get, private set +""" + config + |> prepend newline + |> should + equal + """ + +""" diff --git a/src/Fantomas.Core.Tests/Fantomas.Core.Tests.fsproj b/src/Fantomas.Core.Tests/Fantomas.Core.Tests.fsproj index dec7da75c..f764d1de9 100644 --- a/src/Fantomas.Core.Tests/Fantomas.Core.Tests.fsproj +++ b/src/Fantomas.Core.Tests/Fantomas.Core.Tests.fsproj @@ -133,6 +133,7 @@ + diff --git a/src/Fantomas.Core.Tests/NullnessTests.fs b/src/Fantomas.Core.Tests/NullnessTests.fs index 288dd1edb..25e12cb28 100644 --- a/src/Fantomas.Core.Tests/NullnessTests.fs +++ b/src/Fantomas.Core.Tests/NullnessTests.fs @@ -5,12 +5,97 @@ open FsUnit open Fantomas.Core.Tests.TestHelpers [] -let ``abstract property`` () = +let ``du case of string or null`` () = formatSourceString """ -[] -type AbstractBase() = - abstract Property1 : string | null with get, set +type DU = MyCase of (string | null) +""" + config + |> prepend newline + |> should + equal + """ + +""" + +[] +let ``multiple or type`` () = + formatSourceString + """ +let myFunc ("abc" | "" : string | null | "123") = 15 +""" + config + |> prepend newline + |> should + equal + """ + +""" + +[] +let ``null type constraint`` () = + formatSourceString + """ +let myFunc() : 'T when 'T : not struct and 'T:null = null +""" + config + |> prepend newline + |> should + equal + """ + +""" + +[] +let ``not null type constraint`` () = + formatSourceString + """ +let myFunc (x: 'T when 'T: not null) = 42 +""" + config + |> prepend newline + |> should + equal + """ + +""" + +[] +let ``not null in type constraints`` () = + formatSourceString + """ +type C<'T when 'T: not null> = class end +""" + config + |> prepend newline + |> should + equal + """ + +""" + +[] +let ``or null pattern`` () = + formatSourceString + """ +match x with +| :? string | null -> () +""" + config + |> prepend newline + |> should + equal + """ + +""" + +[] +let ``nullness in signature file`` () = + formatSignatureString + """ +namespace Meh + +type DU = MyCase of (string | null) """ config |> prepend newline From bd7e887bb859da7f2d1712f0ba0fcee7dfb73c3b Mon Sep 17 00:00:00 2001 From: nojaf Date: Fri, 13 Sep 2024 10:26:15 +0200 Subject: [PATCH 04/20] Use and bang keyword from trivia. Thanks Edgar! --- src/Fantomas.Core/ASTTransformer.fs | 21 ++++++++++++--------- 1 file changed, 12 insertions(+), 9 deletions(-) diff --git a/src/Fantomas.Core/ASTTransformer.fs b/src/Fantomas.Core/ASTTransformer.fs index 3b667beb2..bd9620fa3 100644 --- a/src/Fantomas.Core/ASTTransformer.fs +++ b/src/Fantomas.Core/ASTTransformer.fs @@ -333,15 +333,18 @@ let rec collectComputationExpressionStatements let andBangs = andBangs - |> List.map (fun (SynExprAndBang(_, _, _, ap, ae, StartRange 4 (mAnd, m), trivia)) -> - ExprAndBang( - stn "and!" mAnd, - mkPat creationAide ap, - stn "=" trivia.EqualsRange, - mkExpr creationAide ae, - m - ) - |> ComputationExpressionStatement.AndBangStatement) + |> List.map + (fun + (SynExprAndBang(_, + _, + _, + ap, + ae, + m, + { AndBangKeyword = mAnd + EqualsRange = mEq })) -> + ExprAndBang(stn "and!" mAnd, mkPat creationAide ap, stn "=" mEq, mkExpr creationAide ae, m) + |> ComputationExpressionStatement.AndBangStatement) collectComputationExpressionStatements creationAide body (fun bodyStatements -> [ letOrUseBang; yield! andBangs; yield! bodyStatements ] |> finalContinuation) From 2f97828b9f61f040f9d83830a9b53d7231d7355e Mon Sep 17 00:00:00 2001 From: nojaf Date: Fri, 13 Sep 2024 11:06:48 +0200 Subject: [PATCH 05/20] Update SDK in Dockerfile --- .devcontainer/Dockerfile | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.devcontainer/Dockerfile b/.devcontainer/Dockerfile index 084ce71ec..6b6ba5ded 100644 --- a/.devcontainer/Dockerfile +++ b/.devcontainer/Dockerfile @@ -1,4 +1,4 @@ -FROM mcr.microsoft.com/dotnet/sdk:8.0.300 +FROM mcr.microsoft.com/dotnet/nightly/sdk:9.0 # Avoid warnings by switching to noninteractive ENV DEBIAN_FRONTEND=noninteractive From 17dd26e009ec387bec3c5b0187b72862a14dc2a3 Mon Sep 17 00:00:00 2001 From: nojaf Date: Fri, 13 Sep 2024 11:08:57 +0200 Subject: [PATCH 06/20] Reuse mkSynAccess for SynValSigAccess.Single --- src/Fantomas.Core/ASTTransformer.fs | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/src/Fantomas.Core/ASTTransformer.fs b/src/Fantomas.Core/ASTTransformer.fs index bd9620fa3..faf8998d1 100644 --- a/src/Fantomas.Core/ASTTransformer.fs +++ b/src/Fantomas.Core/ASTTransformer.fs @@ -78,9 +78,11 @@ let mkSynAccess (vis: SynAccess option) = | Some(SynAccess.Private range) -> Some(stn "private" range) | Some(SynAccess.Public range) -> Some(stn "public" range) +/// https://fsharp.github.io/fsharp-compiler-docs/reference/fsharp-compiler-syntax-synvalsigaccess.html let mkSynValSigAccess (vis: SynValSigAccess) = - // https://fsharp.github.io/fsharp-compiler-docs/reference/fsharp-compiler-syntax-synvalsigaccess.html - failwith "todo SynValSigAccess: %A" vis + match vis with + | SynValSigAccess.Single(accessibility = vis) -> mkSynAccess vis + | _ -> failwithf "todo SynValSigAccess: %A" vis let parseExpressionInSynBinding returnInfo expr = match returnInfo, expr with From 09c15388b1157e53109f8fd2455e6efc2b0050ba Mon Sep 17 00:00:00 2001 From: nojaf Date: Fri, 13 Sep 2024 11:29:09 +0200 Subject: [PATCH 07/20] Fix existing tests --- src/Fantomas.Core.Tests/AutoPropertiesTests.fs | 2 +- src/Fantomas.Core.Tests/NullnessTests.fs | 6 ++++-- src/Fantomas.Core/ASTTransformer.fs | 1 + 3 files changed, 6 insertions(+), 3 deletions(-) diff --git a/src/Fantomas.Core.Tests/AutoPropertiesTests.fs b/src/Fantomas.Core.Tests/AutoPropertiesTests.fs index acccf16f5..a0d887ca5 100644 --- a/src/Fantomas.Core.Tests/AutoPropertiesTests.fs +++ b/src/Fantomas.Core.Tests/AutoPropertiesTests.fs @@ -25,7 +25,7 @@ let ``public get, private set in signature`` () = """ module A -type X() = +type X = member val internal Y: int = 7 with public get, private set """ config diff --git a/src/Fantomas.Core.Tests/NullnessTests.fs b/src/Fantomas.Core.Tests/NullnessTests.fs index 25e12cb28..981d2725d 100644 --- a/src/Fantomas.Core.Tests/NullnessTests.fs +++ b/src/Fantomas.Core.Tests/NullnessTests.fs @@ -43,7 +43,7 @@ let myFunc() : 'T when 'T : not struct and 'T:null = null |> should equal """ - +let myFunc () : 'T when 'T: not struct and 'T: null = null """ [] @@ -86,7 +86,9 @@ match x with |> should equal """ - +match x with +| :? string +| null -> () """ [] diff --git a/src/Fantomas.Core/ASTTransformer.fs b/src/Fantomas.Core/ASTTransformer.fs index faf8998d1..308ca96ff 100644 --- a/src/Fantomas.Core/ASTTransformer.fs +++ b/src/Fantomas.Core/ASTTransformer.fs @@ -81,6 +81,7 @@ let mkSynAccess (vis: SynAccess option) = /// https://fsharp.github.io/fsharp-compiler-docs/reference/fsharp-compiler-syntax-synvalsigaccess.html let mkSynValSigAccess (vis: SynValSigAccess) = match vis with + | SynValSigAccess.GetSet(accessibility = vis; getterAccessibility = None; setterAccessibility = None) | SynValSigAccess.Single(accessibility = vis) -> mkSynAccess vis | _ -> failwithf "todo SynValSigAccess: %A" vis From 31d7e2f2028aeaa19df3f1fb19ae4d5b2b91b986 Mon Sep 17 00:00:00 2001 From: nojaf Date: Fri, 13 Sep 2024 11:33:16 +0200 Subject: [PATCH 08/20] Correct signature in test --- src/Fantomas.Core.Tests/AutoPropertiesTests.fs | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/Fantomas.Core.Tests/AutoPropertiesTests.fs b/src/Fantomas.Core.Tests/AutoPropertiesTests.fs index a0d887ca5..288fcf496 100644 --- a/src/Fantomas.Core.Tests/AutoPropertiesTests.fs +++ b/src/Fantomas.Core.Tests/AutoPropertiesTests.fs @@ -26,7 +26,8 @@ let ``public get, private set in signature`` () = module A type X = - member val internal Y: int = 7 with public get, private set + new: unit -> X + member internal Y: int with public get, private set """ config |> prepend newline From 6056586f4d80720b915dc89eeb4b66eb76ad27af Mon Sep 17 00:00:00 2001 From: nojaf Date: Fri, 13 Sep 2024 11:37:23 +0200 Subject: [PATCH 09/20] Support SynType.WithNull --- src/Fantomas.Core/ASTTransformer.fs | 2 ++ 1 file changed, 2 insertions(+) diff --git a/src/Fantomas.Core/ASTTransformer.fs b/src/Fantomas.Core/ASTTransformer.fs index 308ca96ff..3736e6f8b 100644 --- a/src/Fantomas.Core/ASTTransformer.fs +++ b/src/Fantomas.Core/ASTTransformer.fs @@ -2321,6 +2321,8 @@ let mkType (creationAide: CreationAide) (t: SynType) : Type = yield Choice1Of2(mkType creationAide t) ] TypeIntersectionNode(typesAndSeparators, m) |> Type.Intersection + | SynType.StaticConstantNull(m) -> stn "null" m |> Type.Var + | SynType.WithNull(innerType, ambivalent, range) -> failwithf $"SynType.WithNull %A{(innerType, ambivalent, range)}" | t -> failwith $"unexpected type: %A{t}" let rec (|OpenL|_|) = From 5e84a6871c691eb1057c3bda3968589880df2354 Mon Sep 17 00:00:00 2001 From: nojaf Date: Fri, 13 Sep 2024 11:50:40 +0200 Subject: [PATCH 10/20] Add support for SynType.WithNull --- src/Fantomas.Core.Tests/NullnessTests.fs | 6 ++++-- src/Fantomas.Core/ASTTransformer.fs | 7 ++++++- 2 files changed, 10 insertions(+), 3 deletions(-) diff --git a/src/Fantomas.Core.Tests/NullnessTests.fs b/src/Fantomas.Core.Tests/NullnessTests.fs index 981d2725d..7cafeb700 100644 --- a/src/Fantomas.Core.Tests/NullnessTests.fs +++ b/src/Fantomas.Core.Tests/NullnessTests.fs @@ -15,7 +15,7 @@ type DU = MyCase of (string | null) |> should equal """ - +type DU = MyCase of (string | null) """ [] @@ -29,7 +29,7 @@ let myFunc ("abc" | "" : string | null | "123") = 15 |> should equal """ - +let myFunc ("abc" | "": string | null | "123") = 15 """ [] @@ -104,5 +104,7 @@ type DU = MyCase of (string | null) |> should equal """ +namespace Meh +type DU = MyCase of (string | null) """ diff --git a/src/Fantomas.Core/ASTTransformer.fs b/src/Fantomas.Core/ASTTransformer.fs index 3736e6f8b..4c61e24d1 100644 --- a/src/Fantomas.Core/ASTTransformer.fs +++ b/src/Fantomas.Core/ASTTransformer.fs @@ -2322,7 +2322,12 @@ let mkType (creationAide: CreationAide) (t: SynType) : Type = TypeIntersectionNode(typesAndSeparators, m) |> Type.Intersection | SynType.StaticConstantNull(m) -> stn "null" m |> Type.Var - | SynType.WithNull(innerType, ambivalent, range) -> failwithf $"SynType.WithNull %A{(innerType, ambivalent, range)}" + // string | null + | SynType.WithNull(innerType, _, EndRange 4 (mNull, m)) -> + let nullType = stn "null" mNull |> Type.Var + + TypeOrNode(mkType creationAide innerType, stn "|" Range.Zero, nullType, m) + |> Type.Or | t -> failwith $"unexpected type: %A{t}" let rec (|OpenL|_|) = From 93bbf46399a3eafab0edb78620a03e1953778cf0 Mon Sep 17 00:00:00 2001 From: nojaf Date: Fri, 13 Sep 2024 12:07:46 +0200 Subject: [PATCH 11/20] Add support for SynTypeConstraint.WhereTyparNotSupportsNull --- src/Fantomas.Core.Tests/NullnessTests.fs | 4 ++-- src/Fantomas.Core/ASTTransformer.fs | 5 +++-- src/Fantomas.Core/CodePrinter.fs | 7 +++++++ src/Fantomas.Core/SyntaxOak.fs | 11 +++++++++++ 4 files changed, 23 insertions(+), 4 deletions(-) diff --git a/src/Fantomas.Core.Tests/NullnessTests.fs b/src/Fantomas.Core.Tests/NullnessTests.fs index 7cafeb700..c3adc78df 100644 --- a/src/Fantomas.Core.Tests/NullnessTests.fs +++ b/src/Fantomas.Core.Tests/NullnessTests.fs @@ -57,7 +57,7 @@ let myFunc (x: 'T when 'T: not null) = 42 |> should equal """ - +let myFunc (x: 'T when 'T: not null) = 42 """ [] @@ -71,7 +71,7 @@ type C<'T when 'T: not null> = class end |> should equal """ - +type C<'T when 'T: not null> = class end """ [] diff --git a/src/Fantomas.Core/ASTTransformer.fs b/src/Fantomas.Core/ASTTransformer.fs index 4c61e24d1..a4e58cc3d 100644 --- a/src/Fantomas.Core/ASTTransformer.fs +++ b/src/Fantomas.Core/ASTTransformer.fs @@ -2178,8 +2178,9 @@ let mkSynTypeConstraint (creationAide: CreationAide) (tc: SynTypeConstraint) : T TypeConstraintEnumOrDelegateNode(mkSynTypar tp, "delegate", List.map (mkType creationAide) ts, m) |> TypeConstraint.EnumOrDelegate | SynTypeConstraint.WhereSelfConstrained(t, _) -> mkType creationAide t |> TypeConstraint.WhereSelfConstrained - | SynTypeConstraint.WhereTyparNotSupportsNull(genericName, range) -> - failwithf "todo WhereTyparNotSupportsNull : %A" (genericName, range) + | SynTypeConstraint.WhereTyparNotSupportsNull(typar, EndRange 4 (mNull, m)) -> + TypeConstraintWhereNotSupportsNull(mkSynTypar typar, stn "null" mNull, m) + |> TypeConstraint.WhereNotSupportsNull // Arrow type is right-associative let rec (|TFuns|_|) = diff --git a/src/Fantomas.Core/CodePrinter.fs b/src/Fantomas.Core/CodePrinter.fs index 6e68cf381..3b4839519 100644 --- a/src/Fantomas.Core/CodePrinter.fs +++ b/src/Fantomas.Core/CodePrinter.fs @@ -3151,6 +3151,13 @@ let genTypeConstraint (tc: TypeConstraint) = +> !- ">" |> genNode node | TypeConstraint.WhereSelfConstrained t -> genType t + | TypeConstraint.WhereNotSupportsNull node -> + genSingleTextNode node.Typar + +> sepColon + +> !- "not" + +> sepSpace + +> genSingleTextNode node.Null + |> genNode node let genTypeConstraints (tcs: TypeConstraint list) = let short = colPre (sepSpace +> !- "when ") wordAnd tcs genTypeConstraint diff --git a/src/Fantomas.Core/SyntaxOak.fs b/src/Fantomas.Core/SyntaxOak.fs index 5d2de5a89..fe1798aa0 100644 --- a/src/Fantomas.Core/SyntaxOak.fs +++ b/src/Fantomas.Core/SyntaxOak.fs @@ -2787,6 +2787,15 @@ type TypeConstraintEnumOrDelegateNode(typar: SingleTextNode, verb: string, ts: T member val Verb = verb member val Types = ts +type TypeConstraintWhereNotSupportsNull(typar: SingleTextNode, nullNode: SingleTextNode, range) = + inherit NodeBase(range) + + override val Children: Node array = [| yield typar; yield nullNode |] + + member val Typar = typar + + member val Null = nullNode + [] type TypeConstraint = | Single of TypeConstraintSingleNode @@ -2795,6 +2804,7 @@ type TypeConstraint = | SupportsMember of TypeConstraintSupportsMemberNode | EnumOrDelegate of TypeConstraintEnumOrDelegateNode | WhereSelfConstrained of Type + | WhereNotSupportsNull of TypeConstraintWhereNotSupportsNull static member Node(tc: TypeConstraint) : Node = match tc with @@ -2804,6 +2814,7 @@ type TypeConstraint = | SupportsMember n -> n | EnumOrDelegate n -> n | WhereSelfConstrained t -> Type.Node t + | WhereNotSupportsNull n -> n type UnitOfMeasureNode(lessThan: SingleTextNode, measure: Measure, greaterThan: SingleTextNode, range) = inherit NodeBase(range) From 21b41e149f8cb29089359fe4faaa356af6597c1f Mon Sep 17 00:00:00 2001 From: nojaf Date: Fri, 13 Sep 2024 14:28:59 +0200 Subject: [PATCH 12/20] Support SynValSigAccess --- .../AutoPropertiesTests.fs | 57 ++++++++++ src/Fantomas.Core/ASTTransformer.fs | 106 ++++++++++++------ 2 files changed, 129 insertions(+), 34 deletions(-) diff --git a/src/Fantomas.Core.Tests/AutoPropertiesTests.fs b/src/Fantomas.Core.Tests/AutoPropertiesTests.fs index 288fcf496..ab6a962df 100644 --- a/src/Fantomas.Core.Tests/AutoPropertiesTests.fs +++ b/src/Fantomas.Core.Tests/AutoPropertiesTests.fs @@ -16,7 +16,40 @@ type X() = |> should equal """ +type X() = + member val Y: int = 7 with public get, private set +""" +[] +let ``plain get, private set`` () = + formatSourceString + """ +type X() = + member val Y: int = 7 with get, private set +""" + config + |> prepend newline + |> should + equal + """ +type X() = + member val Y: int = 7 with get, private set +""" + +[] +let ``internal get, plain set`` () = + formatSourceString + """ +type X() = + member val Y: int = 7 with internal get, set +""" + config + |> prepend newline + |> should + equal + """ +type X() = + member val Y: int = 7 with internal get, set """ [] @@ -34,5 +67,29 @@ type X = |> should equal """ +module A + +type X = + new: unit -> X + member internal Y: int with public get, private set +""" +[] +let ``abstract member with public get, private set`` () = + formatSignatureString + """ +namespace Meh + +type X = + abstract Y: int with public get, private set +""" + config + |> prepend newline + |> should + equal + """ +namespace Meh + +type X = + abstract Y: int with public get, private set """ diff --git a/src/Fantomas.Core/ASTTransformer.fs b/src/Fantomas.Core/ASTTransformer.fs index a4e58cc3d..ccade4454 100644 --- a/src/Fantomas.Core/ASTTransformer.fs +++ b/src/Fantomas.Core/ASTTransformer.fs @@ -78,12 +78,15 @@ let mkSynAccess (vis: SynAccess option) = | Some(SynAccess.Private range) -> Some(stn "private" range) | Some(SynAccess.Public range) -> Some(stn "public" range) -/// https://fsharp.github.io/fsharp-compiler-docs/reference/fsharp-compiler-syntax-synvalsigaccess.html -let mkSynValSigAccess (vis: SynValSigAccess) = - match vis with - | SynValSigAccess.GetSet(accessibility = vis; getterAccessibility = None; setterAccessibility = None) - | SynValSigAccess.Single(accessibility = vis) -> mkSynAccess vis - | _ -> failwithf "todo SynValSigAccess: %A" vis +let (|AccessSynValSigAccess|) (valSigAccess: SynValSigAccess) = + match valSigAccess with + | SynValSigAccess.GetSet(accessibility = vis) + | SynValSigAccess.Single(accessibility = vis) -> vis + +let (|SynValSigAccessAll|) (valSigAccess: SynValSigAccess) = + match valSigAccess with + | SynValSigAccess.Single(vis) -> vis, None, None + | SynValSigAccess.GetSet(vis, g, s) -> vis, g, s let parseExpressionInSynBinding returnInfo expr = match returnInfo, expr with @@ -2652,20 +2655,44 @@ let mkTypeDefn TypeDefnRegularNode(typeNameNode, allMembers, typeDefnRange) |> TypeDefn.Regular | _ -> failwithf "Could not create a TypeDefn for %A" typeRepr -let mkWithGetSet (withKeyword: range option) (getSet: GetSetKeywords option) = +let mkWithGetSet + (withKeyword: range option) + (getSet: GetSetKeywords option) + (visGet: SynAccess option) + (visSet: SynAccess option) + = match withKeyword, getSet with | Some mWith, Some gs -> let withNode = stn "with" mWith let m = unionRanges mWith gs.Range + let visNodes vis = Option.toList (mkSynAccess vis) match gs with - | GetSetKeywords.Get mGet -> Some(MultipleTextsNode([ withNode; stn "get" mGet ], m)) - | GetSetKeywords.Set mSet -> Some(MultipleTextsNode([ withNode; stn "set" mSet ], m)) + | GetSetKeywords.Get mGet -> Some(MultipleTextsNode([ withNode; yield! visNodes visGet; stn "get" mGet ], m)) + | GetSetKeywords.Set mSet -> Some(MultipleTextsNode([ withNode; yield! visNodes visSet; stn "set" mSet ], m)) | GetSetKeywords.GetSet(mGet, mSet) -> if rangeBeforePos mGet mSet.Start then - Some(MultipleTextsNode([ withNode; stn "get," mGet; stn "set" mSet ], m)) + Some( + MultipleTextsNode( + [ withNode + yield! visNodes visGet + stn "get," mGet + yield! visNodes visSet + stn "set" mSet ], + m + ) + ) else - Some(MultipleTextsNode([ withNode; stn "set," mSet; stn "get" mGet ], m)) + Some( + MultipleTextsNode( + [ withNode + yield! visNodes visSet + stn "set," mSet + yield! visNodes visGet + stn "get" mGet ], + m + ) + ) | _ -> None let mkPropertyGetSetBinding @@ -2846,35 +2873,45 @@ let mkMemberDefn (creationAide: CreationAide) (md: SynMemberDefn) = memberDefinitionRange ) |> MemberDefn.Interface - | SynMemberDefn.AutoProperty(ats, - _isStatic, - ident, - typeOpt, - _, - _, - _, - px, - ao, - e, - _, - { LeadingKeyword = lk - EqualsRange = Some mEq - WithKeyword = mWith - GetSetKeywords = mGS }) -> + | SynMemberDefn.AutoProperty( + attributes = ats + ident = ident + typeOpt = typeOpt + xmlDoc = px + accessibility = valSigAccess + synExpr = e + trivia = { LeadingKeyword = lk + EqualsRange = Some mEq + WithKeyword = mWith + GetSetKeywords = mGS }) -> + let vis, getVis, setVis = + match valSigAccess with + | SynValSigAccess.Single(ao) -> ao, None, None + | SynValSigAccess.GetSet(ao, g, s) -> ao, g, s + MemberDefnAutoPropertyNode( mkXmlDoc px, mkAttributes creationAide ats, mkSynLeadingKeyword lk, - mkSynValSigAccess ao, + mkSynAccess vis, mkIdent ident, Option.map (mkType creationAide) typeOpt, stn "=" mEq, mkExpr creationAide e, - mkWithGetSet mWith mGS, + mkWithGetSet mWith mGS getVis setVis, memberDefinitionRange ) |> MemberDefn.AutoProperty - | SynMemberDefn.AbstractSlot(SynValSig(ats, ident, tds, t, _, _, _, px, _ao, _, _, trivia), _, _, abstractSlotTrivia) -> + | SynMemberDefn.AbstractSlot( + slotSig = SynValSig( + attributes = ats + ident = ident + explicitTypeParams = tds + synType = t + xmlDoc = px + accessibility = SynValSigAccessAll(_ao, visGet, visSet) + trivia = trivia) + trivia = abstractSlotTrivia) -> MemberDefnAbstractSlotNode( mkXmlDoc px, mkAttributes creationAide ats, @@ -2882,7 +2919,7 @@ let mkMemberDefn (creationAide: CreationAide) (md: SynMemberDefn) = mkSynIdent ident, mkSynValTyparDecls creationAide (Some tds), mkType creationAide t, - mkWithGetSet trivia.WithKeyword abstractSlotTrivia.GetSetKeywords, + mkWithGetSet trivia.WithKeyword abstractSlotTrivia.GetSetKeywords visGet visSet, memberDefinitionRange ) |> MemberDefn.AbstractSlot @@ -3034,7 +3071,7 @@ let mkMemberDefn (creationAide: CreationAide) (md: SynMemberDefn) = let mkVal (creationAide: CreationAide) - (SynValSig(ats, synIdent, vtd, t, _vi, _isInline, isMutable, px, ao, eo, range, trivia)) + (SynValSig(ats, synIdent, vtd, t, _vi, _isInline, isMutable, px, AccessSynValSigAccess(ao), eo, range, trivia)) : ValNode = let lk = match trivia.LeadingKeyword with @@ -3047,7 +3084,7 @@ let mkVal lk, Option.map (stn "inline") trivia.InlineKeyword, isMutable, - mkSynValSigAccess ao, + mkSynAccess ao, mkSynIdent synIdent, mkSynValTyparDecls creationAide (Some vtd), mkType creationAide t, @@ -3061,11 +3098,12 @@ let mkMemberSig (creationAide: CreationAide) (ms: SynMemberSig) = match ms with | SynMemberSig.Member(vs, _, _, memberTrivia) -> - let (SynValSig(trivia = trivia)) = vs + let (SynValSig(trivia = trivia; accessibility = SynValSigAccessAll(_ao, visGet, visSet))) = + vs MemberDefnSigMemberNode( mkVal creationAide vs, - mkWithGetSet trivia.WithKeyword memberTrivia.GetSetKeywords, + mkWithGetSet trivia.WithKeyword memberTrivia.GetSetKeywords visGet visSet, memberSigRange ) |> MemberDefn.SigMember From aef5c596a00ba519e2e1d071808355370a424a2e Mon Sep 17 00:00:00 2001 From: nojaf Date: Fri, 13 Sep 2024 14:33:38 +0200 Subject: [PATCH 13/20] Go back to 8.0.400 SDK --- .devcontainer/Dockerfile | 2 +- Directory.Packages.props | 2 +- global.json | 4 ++-- src/Fantomas.Benchmarks/packages.lock.json | 10 +++++----- src/Fantomas.Client.Tests/packages.lock.json | 6 +++--- src/Fantomas.Core.Tests/packages.lock.json | 10 +++++----- src/Fantomas.Core/packages.lock.json | 8 ++++---- src/Fantomas.FCS/Fantomas.FCS.fsproj | 2 +- src/Fantomas.FCS/packages.lock.json | 6 +++--- src/Fantomas.Tests/packages.lock.json | 12 ++++++------ src/Fantomas/packages.lock.json | 10 +++++----- 11 files changed, 36 insertions(+), 36 deletions(-) diff --git a/.devcontainer/Dockerfile b/.devcontainer/Dockerfile index 6b6ba5ded..bda0692f1 100644 --- a/.devcontainer/Dockerfile +++ b/.devcontainer/Dockerfile @@ -1,4 +1,4 @@ -FROM mcr.microsoft.com/dotnet/nightly/sdk:9.0 +FROM mcr.microsoft.com/dotnet/sdk:8.0.400 # Avoid warnings by switching to noninteractive ENV DEBIAN_FRONTEND=noninteractive diff --git a/Directory.Packages.props b/Directory.Packages.props index f11715b05..63af138ee 100644 --- a/Directory.Packages.props +++ b/Directory.Packages.props @@ -4,7 +4,7 @@ true - + diff --git a/global.json b/global.json index 2c089ece3..d66f18b16 100644 --- a/global.json +++ b/global.json @@ -1,6 +1,6 @@ { "sdk": { - "version": "9.0.100-rc.1.24452.12", - "rollForward": "latestPatch" + "version": "8.0.400", + "rollForward": "latestMinor" } } \ No newline at end of file diff --git a/src/Fantomas.Benchmarks/packages.lock.json b/src/Fantomas.Benchmarks/packages.lock.json index cbcc1672c..8458cdd64 100644 --- a/src/Fantomas.Benchmarks/packages.lock.json +++ b/src/Fantomas.Benchmarks/packages.lock.json @@ -28,9 +28,9 @@ }, "FSharp.Core": { "type": "Direct", - "requested": "[9.0.100-beta.24422.2, )", - "resolved": "9.0.100-beta.24422.2", - "contentHash": "NmzJmz7DS6h+kAW14ooG396DAr2xU8NbAj73RNZvQg+aNaLC0PLJYcvsQ8r6Hb0ZUZxKnjxTn3ROsQiSDSNaKg==" + "requested": "[8.0.400, )", + "resolved": "8.0.400", + "contentHash": "kHMdDDmlZl98tujgHCmL8/HNH9VKbxsRMC9s7wbwr4noR40SSa5D4d00yF8cMK52s8jabVuiLLcrUw9r+PkKDQ==" }, "G-Research.FSharp.Analyzers": { "type": "Direct", @@ -274,14 +274,14 @@ "fantomas.core": { "type": "Project", "dependencies": { - "FSharp.Core": "[9.0.100-beta.24422.2, )", + "FSharp.Core": "[8.0.400, )", "Fantomas.FCS": "[1.0.0, )" } }, "fantomas.fcs": { "type": "Project", "dependencies": { - "FSharp.Core": "[9.0.100-beta.24422.2, )", + "FSharp.Core": "[8.0.400, )", "System.Collections.Immutable": "[7.0.0, )", "System.Diagnostics.DiagnosticSource": "[7.0.0, )", "System.Memory": "[4.5.5, )", diff --git a/src/Fantomas.Client.Tests/packages.lock.json b/src/Fantomas.Client.Tests/packages.lock.json index d82dc6968..c7b595497 100644 --- a/src/Fantomas.Client.Tests/packages.lock.json +++ b/src/Fantomas.Client.Tests/packages.lock.json @@ -16,9 +16,9 @@ }, "FSharp.Core": { "type": "Direct", - "requested": "[9.0.100-beta.24422.2, )", - "resolved": "9.0.100-beta.24422.2", - "contentHash": "NmzJmz7DS6h+kAW14ooG396DAr2xU8NbAj73RNZvQg+aNaLC0PLJYcvsQ8r6Hb0ZUZxKnjxTn3ROsQiSDSNaKg==" + "requested": "[8.0.400, )", + "resolved": "8.0.400", + "contentHash": "kHMdDDmlZl98tujgHCmL8/HNH9VKbxsRMC9s7wbwr4noR40SSa5D4d00yF8cMK52s8jabVuiLLcrUw9r+PkKDQ==" }, "G-Research.FSharp.Analyzers": { "type": "Direct", diff --git a/src/Fantomas.Core.Tests/packages.lock.json b/src/Fantomas.Core.Tests/packages.lock.json index e6a25d337..24469b53b 100644 --- a/src/Fantomas.Core.Tests/packages.lock.json +++ b/src/Fantomas.Core.Tests/packages.lock.json @@ -19,9 +19,9 @@ }, "FSharp.Core": { "type": "Direct", - "requested": "[9.0.100-beta.24422.2, )", - "resolved": "9.0.100-beta.24422.2", - "contentHash": "NmzJmz7DS6h+kAW14ooG396DAr2xU8NbAj73RNZvQg+aNaLC0PLJYcvsQ8r6Hb0ZUZxKnjxTn3ROsQiSDSNaKg==" + "requested": "[8.0.400, )", + "resolved": "8.0.400", + "contentHash": "kHMdDDmlZl98tujgHCmL8/HNH9VKbxsRMC9s7wbwr4noR40SSa5D4d00yF8cMK52s8jabVuiLLcrUw9r+PkKDQ==" }, "FsUnit": { "type": "Direct", @@ -144,14 +144,14 @@ "fantomas.core": { "type": "Project", "dependencies": { - "FSharp.Core": "[9.0.100-beta.24422.2, )", + "FSharp.Core": "[8.0.400, )", "Fantomas.FCS": "[1.0.0, )" } }, "fantomas.fcs": { "type": "Project", "dependencies": { - "FSharp.Core": "[9.0.100-beta.24422.2, )", + "FSharp.Core": "[8.0.400, )", "System.Collections.Immutable": "[7.0.0, )", "System.Diagnostics.DiagnosticSource": "[7.0.0, )", "System.Memory": "[4.5.5, )", diff --git a/src/Fantomas.Core/packages.lock.json b/src/Fantomas.Core/packages.lock.json index be2ca1511..644922891 100644 --- a/src/Fantomas.Core/packages.lock.json +++ b/src/Fantomas.Core/packages.lock.json @@ -22,9 +22,9 @@ }, "FSharp.Core": { "type": "Direct", - "requested": "[9.0.100-beta.24422.2, )", - "resolved": "9.0.100-beta.24422.2", - "contentHash": "NmzJmz7DS6h+kAW14ooG396DAr2xU8NbAj73RNZvQg+aNaLC0PLJYcvsQ8r6Hb0ZUZxKnjxTn3ROsQiSDSNaKg==" + "requested": "[8.0.400, )", + "resolved": "8.0.400", + "contentHash": "kHMdDDmlZl98tujgHCmL8/HNH9VKbxsRMC9s7wbwr4noR40SSa5D4d00yF8cMK52s8jabVuiLLcrUw9r+PkKDQ==" }, "G-Research.FSharp.Analyzers": { "type": "Direct", @@ -127,7 +127,7 @@ "fantomas.fcs": { "type": "Project", "dependencies": { - "FSharp.Core": "[9.0.100-beta.24422.2, )", + "FSharp.Core": "[8.0.400, )", "System.Collections.Immutable": "[7.0.0, )", "System.Diagnostics.DiagnosticSource": "[7.0.0, )", "System.Memory": "[4.5.5, )", diff --git a/src/Fantomas.FCS/Fantomas.FCS.fsproj b/src/Fantomas.FCS/Fantomas.FCS.fsproj index 00fa651db..8ef624318 100644 --- a/src/Fantomas.FCS/Fantomas.FCS.fsproj +++ b/src/Fantomas.FCS/Fantomas.FCS.fsproj @@ -6,7 +6,7 @@ $(NoWarn);57; $(NoWarn);1204 $(NoWarn);1178 - $(DefineConstants);COMPILER;FSHARPCORE_USE_PACKAGE + $(DefineConstants);COMPILER;FSHARPCORE_USE_PACKAGE;NO_CHECKNULLS generated\$(TargetFramework)\ generated\$(TargetFramework)\ true diff --git a/src/Fantomas.FCS/packages.lock.json b/src/Fantomas.FCS/packages.lock.json index b5823fad7..d232fc558 100644 --- a/src/Fantomas.FCS/packages.lock.json +++ b/src/Fantomas.FCS/packages.lock.json @@ -22,9 +22,9 @@ }, "FSharp.Core": { "type": "Direct", - "requested": "[9.0.100-beta.24422.2, )", - "resolved": "9.0.100-beta.24422.2", - "contentHash": "NmzJmz7DS6h+kAW14ooG396DAr2xU8NbAj73RNZvQg+aNaLC0PLJYcvsQ8r6Hb0ZUZxKnjxTn3ROsQiSDSNaKg==" + "requested": "[8.0.400, )", + "resolved": "8.0.400", + "contentHash": "kHMdDDmlZl98tujgHCmL8/HNH9VKbxsRMC9s7wbwr4noR40SSa5D4d00yF8cMK52s8jabVuiLLcrUw9r+PkKDQ==" }, "FsLexYacc": { "type": "Direct", diff --git a/src/Fantomas.Tests/packages.lock.json b/src/Fantomas.Tests/packages.lock.json index 70f7fa48f..076608839 100644 --- a/src/Fantomas.Tests/packages.lock.json +++ b/src/Fantomas.Tests/packages.lock.json @@ -19,9 +19,9 @@ }, "FSharp.Core": { "type": "Direct", - "requested": "[9.0.100-beta.24422.2, )", - "resolved": "9.0.100-beta.24422.2", - "contentHash": "NmzJmz7DS6h+kAW14ooG396DAr2xU8NbAj73RNZvQg+aNaLC0PLJYcvsQ8r6Hb0ZUZxKnjxTn3ROsQiSDSNaKg==" + "requested": "[8.0.400, )", + "resolved": "8.0.400", + "contentHash": "kHMdDDmlZl98tujgHCmL8/HNH9VKbxsRMC9s7wbwr4noR40SSa5D4d00yF8cMK52s8jabVuiLLcrUw9r+PkKDQ==" }, "FsUnit": { "type": "Direct", @@ -821,7 +821,7 @@ "type": "Project", "dependencies": { "Argu": "[6.2.4, )", - "FSharp.Core": "[9.0.100-beta.24422.2, )", + "FSharp.Core": "[8.0.400, )", "Fantomas.Client": "[1.0.0, )", "Fantomas.Core": "[1.0.0, )", "Ignore": "[0.1.50, )", @@ -846,14 +846,14 @@ "fantomas.core": { "type": "Project", "dependencies": { - "FSharp.Core": "[9.0.100-beta.24422.2, )", + "FSharp.Core": "[8.0.400, )", "Fantomas.FCS": "[1.0.0, )" } }, "fantomas.fcs": { "type": "Project", "dependencies": { - "FSharp.Core": "[9.0.100-beta.24422.2, )", + "FSharp.Core": "[8.0.400, )", "System.Collections.Immutable": "[7.0.0, )", "System.Diagnostics.DiagnosticSource": "[7.0.0, )", "System.Memory": "[4.5.5, )", diff --git a/src/Fantomas/packages.lock.json b/src/Fantomas/packages.lock.json index 8cf056104..6b3dea62a 100644 --- a/src/Fantomas/packages.lock.json +++ b/src/Fantomas/packages.lock.json @@ -38,9 +38,9 @@ }, "FSharp.Core": { "type": "Direct", - "requested": "[9.0.100-beta.24422.2, )", - "resolved": "9.0.100-beta.24422.2", - "contentHash": "NmzJmz7DS6h+kAW14ooG396DAr2xU8NbAj73RNZvQg+aNaLC0PLJYcvsQ8r6Hb0ZUZxKnjxTn3ROsQiSDSNaKg==" + "requested": "[8.0.400, )", + "resolved": "8.0.400", + "contentHash": "kHMdDDmlZl98tujgHCmL8/HNH9VKbxsRMC9s7wbwr4noR40SSa5D4d00yF8cMK52s8jabVuiLLcrUw9r+PkKDQ==" }, "G-Research.FSharp.Analyzers": { "type": "Direct", @@ -898,14 +898,14 @@ "fantomas.core": { "type": "Project", "dependencies": { - "FSharp.Core": "[9.0.100-beta.24422.2, )", + "FSharp.Core": "[8.0.400, )", "Fantomas.FCS": "[1.0.0, )" } }, "fantomas.fcs": { "type": "Project", "dependencies": { - "FSharp.Core": "[9.0.100-beta.24422.2, )", + "FSharp.Core": "[8.0.400, )", "System.Collections.Immutable": "[7.0.0, )", "System.Diagnostics.DiagnosticSource": "[7.0.0, )", "System.Memory": "[4.5.5, )", From 7181e32508e683d2d4c76fc6d4eaa46134600a80 Mon Sep 17 00:00:00 2001 From: nojaf Date: Fri, 13 Sep 2024 15:11:45 +0200 Subject: [PATCH 14/20] Revert F# Core version and add TailCall attribute --- Directory.Packages.props | 2 +- global.json | 2 +- src/Fantomas.Benchmarks/packages.lock.json | 10 +++++----- src/Fantomas.Client.Tests/packages.lock.json | 6 +++--- src/Fantomas.Core.Tests/packages.lock.json | 10 +++++----- src/Fantomas.Core/packages.lock.json | 8 ++++---- src/Fantomas.FCS/Fantomas.FCS.fsproj | 1 + src/Fantomas.FCS/TailCall.fs | 7 +++++++ src/Fantomas.FCS/packages.lock.json | 6 +++--- src/Fantomas.Tests/packages.lock.json | 12 ++++++------ src/Fantomas/packages.lock.json | 10 +++++----- 11 files changed, 41 insertions(+), 33 deletions(-) create mode 100644 src/Fantomas.FCS/TailCall.fs diff --git a/Directory.Packages.props b/Directory.Packages.props index 63af138ee..37b265adc 100644 --- a/Directory.Packages.props +++ b/Directory.Packages.props @@ -4,7 +4,7 @@ true - + diff --git a/global.json b/global.json index d66f18b16..6f6aff9de 100644 --- a/global.json +++ b/global.json @@ -1,6 +1,6 @@ { "sdk": { "version": "8.0.400", - "rollForward": "latestMinor" + "rollForward": "latestPatch" } } \ No newline at end of file diff --git a/src/Fantomas.Benchmarks/packages.lock.json b/src/Fantomas.Benchmarks/packages.lock.json index 8458cdd64..9b5a34797 100644 --- a/src/Fantomas.Benchmarks/packages.lock.json +++ b/src/Fantomas.Benchmarks/packages.lock.json @@ -28,9 +28,9 @@ }, "FSharp.Core": { "type": "Direct", - "requested": "[8.0.400, )", - "resolved": "8.0.400", - "contentHash": "kHMdDDmlZl98tujgHCmL8/HNH9VKbxsRMC9s7wbwr4noR40SSa5D4d00yF8cMK52s8jabVuiLLcrUw9r+PkKDQ==" + "requested": "[6.0.1, )", + "resolved": "6.0.1", + "contentHash": "VrFAiW8dEEekk+0aqlbvMNZzDvYXmgWZwAt68AUBqaWK8RnoEVUNglj66bZzhs4/U63q0EfXlhcEKnH1sTYLjw==" }, "G-Research.FSharp.Analyzers": { "type": "Direct", @@ -274,14 +274,14 @@ "fantomas.core": { "type": "Project", "dependencies": { - "FSharp.Core": "[8.0.400, )", + "FSharp.Core": "[6.0.1, )", "Fantomas.FCS": "[1.0.0, )" } }, "fantomas.fcs": { "type": "Project", "dependencies": { - "FSharp.Core": "[8.0.400, )", + "FSharp.Core": "[6.0.1, )", "System.Collections.Immutable": "[7.0.0, )", "System.Diagnostics.DiagnosticSource": "[7.0.0, )", "System.Memory": "[4.5.5, )", diff --git a/src/Fantomas.Client.Tests/packages.lock.json b/src/Fantomas.Client.Tests/packages.lock.json index c7b595497..c3cc3d7db 100644 --- a/src/Fantomas.Client.Tests/packages.lock.json +++ b/src/Fantomas.Client.Tests/packages.lock.json @@ -16,9 +16,9 @@ }, "FSharp.Core": { "type": "Direct", - "requested": "[8.0.400, )", - "resolved": "8.0.400", - "contentHash": "kHMdDDmlZl98tujgHCmL8/HNH9VKbxsRMC9s7wbwr4noR40SSa5D4d00yF8cMK52s8jabVuiLLcrUw9r+PkKDQ==" + "requested": "[6.0.1, )", + "resolved": "6.0.1", + "contentHash": "VrFAiW8dEEekk+0aqlbvMNZzDvYXmgWZwAt68AUBqaWK8RnoEVUNglj66bZzhs4/U63q0EfXlhcEKnH1sTYLjw==" }, "G-Research.FSharp.Analyzers": { "type": "Direct", diff --git a/src/Fantomas.Core.Tests/packages.lock.json b/src/Fantomas.Core.Tests/packages.lock.json index 24469b53b..9da29aaa1 100644 --- a/src/Fantomas.Core.Tests/packages.lock.json +++ b/src/Fantomas.Core.Tests/packages.lock.json @@ -19,9 +19,9 @@ }, "FSharp.Core": { "type": "Direct", - "requested": "[8.0.400, )", - "resolved": "8.0.400", - "contentHash": "kHMdDDmlZl98tujgHCmL8/HNH9VKbxsRMC9s7wbwr4noR40SSa5D4d00yF8cMK52s8jabVuiLLcrUw9r+PkKDQ==" + "requested": "[6.0.1, )", + "resolved": "6.0.1", + "contentHash": "VrFAiW8dEEekk+0aqlbvMNZzDvYXmgWZwAt68AUBqaWK8RnoEVUNglj66bZzhs4/U63q0EfXlhcEKnH1sTYLjw==" }, "FsUnit": { "type": "Direct", @@ -144,14 +144,14 @@ "fantomas.core": { "type": "Project", "dependencies": { - "FSharp.Core": "[8.0.400, )", + "FSharp.Core": "[6.0.1, )", "Fantomas.FCS": "[1.0.0, )" } }, "fantomas.fcs": { "type": "Project", "dependencies": { - "FSharp.Core": "[8.0.400, )", + "FSharp.Core": "[6.0.1, )", "System.Collections.Immutable": "[7.0.0, )", "System.Diagnostics.DiagnosticSource": "[7.0.0, )", "System.Memory": "[4.5.5, )", diff --git a/src/Fantomas.Core/packages.lock.json b/src/Fantomas.Core/packages.lock.json index 644922891..ed4ccc3fe 100644 --- a/src/Fantomas.Core/packages.lock.json +++ b/src/Fantomas.Core/packages.lock.json @@ -22,9 +22,9 @@ }, "FSharp.Core": { "type": "Direct", - "requested": "[8.0.400, )", - "resolved": "8.0.400", - "contentHash": "kHMdDDmlZl98tujgHCmL8/HNH9VKbxsRMC9s7wbwr4noR40SSa5D4d00yF8cMK52s8jabVuiLLcrUw9r+PkKDQ==" + "requested": "[6.0.1, )", + "resolved": "6.0.1", + "contentHash": "VrFAiW8dEEekk+0aqlbvMNZzDvYXmgWZwAt68AUBqaWK8RnoEVUNglj66bZzhs4/U63q0EfXlhcEKnH1sTYLjw==" }, "G-Research.FSharp.Analyzers": { "type": "Direct", @@ -127,7 +127,7 @@ "fantomas.fcs": { "type": "Project", "dependencies": { - "FSharp.Core": "[8.0.400, )", + "FSharp.Core": "[6.0.1, )", "System.Collections.Immutable": "[7.0.0, )", "System.Diagnostics.DiagnosticSource": "[7.0.0, )", "System.Memory": "[4.5.5, )", diff --git a/src/Fantomas.FCS/Fantomas.FCS.fsproj b/src/Fantomas.FCS/Fantomas.FCS.fsproj index 8ef624318..db012a03f 100644 --- a/src/Fantomas.FCS/Fantomas.FCS.fsproj +++ b/src/Fantomas.FCS/Fantomas.FCS.fsproj @@ -16,6 +16,7 @@ + FSComp.txt diff --git a/src/Fantomas.FCS/TailCall.fs b/src/Fantomas.FCS/TailCall.fs new file mode 100644 index 000000000..5088f93a3 --- /dev/null +++ b/src/Fantomas.FCS/TailCall.fs @@ -0,0 +1,7 @@ +module Microsoft.FSharp.Core + +open System + +[] +type TailCallAttribute() = + inherit Attribute() diff --git a/src/Fantomas.FCS/packages.lock.json b/src/Fantomas.FCS/packages.lock.json index d232fc558..f73abbc81 100644 --- a/src/Fantomas.FCS/packages.lock.json +++ b/src/Fantomas.FCS/packages.lock.json @@ -22,9 +22,9 @@ }, "FSharp.Core": { "type": "Direct", - "requested": "[8.0.400, )", - "resolved": "8.0.400", - "contentHash": "kHMdDDmlZl98tujgHCmL8/HNH9VKbxsRMC9s7wbwr4noR40SSa5D4d00yF8cMK52s8jabVuiLLcrUw9r+PkKDQ==" + "requested": "[6.0.1, )", + "resolved": "6.0.1", + "contentHash": "VrFAiW8dEEekk+0aqlbvMNZzDvYXmgWZwAt68AUBqaWK8RnoEVUNglj66bZzhs4/U63q0EfXlhcEKnH1sTYLjw==" }, "FsLexYacc": { "type": "Direct", diff --git a/src/Fantomas.Tests/packages.lock.json b/src/Fantomas.Tests/packages.lock.json index 076608839..2d6c37764 100644 --- a/src/Fantomas.Tests/packages.lock.json +++ b/src/Fantomas.Tests/packages.lock.json @@ -19,9 +19,9 @@ }, "FSharp.Core": { "type": "Direct", - "requested": "[8.0.400, )", - "resolved": "8.0.400", - "contentHash": "kHMdDDmlZl98tujgHCmL8/HNH9VKbxsRMC9s7wbwr4noR40SSa5D4d00yF8cMK52s8jabVuiLLcrUw9r+PkKDQ==" + "requested": "[6.0.1, )", + "resolved": "6.0.1", + "contentHash": "VrFAiW8dEEekk+0aqlbvMNZzDvYXmgWZwAt68AUBqaWK8RnoEVUNglj66bZzhs4/U63q0EfXlhcEKnH1sTYLjw==" }, "FsUnit": { "type": "Direct", @@ -821,7 +821,7 @@ "type": "Project", "dependencies": { "Argu": "[6.2.4, )", - "FSharp.Core": "[8.0.400, )", + "FSharp.Core": "[6.0.1, )", "Fantomas.Client": "[1.0.0, )", "Fantomas.Core": "[1.0.0, )", "Ignore": "[0.1.50, )", @@ -846,14 +846,14 @@ "fantomas.core": { "type": "Project", "dependencies": { - "FSharp.Core": "[8.0.400, )", + "FSharp.Core": "[6.0.1, )", "Fantomas.FCS": "[1.0.0, )" } }, "fantomas.fcs": { "type": "Project", "dependencies": { - "FSharp.Core": "[8.0.400, )", + "FSharp.Core": "[6.0.1, )", "System.Collections.Immutable": "[7.0.0, )", "System.Diagnostics.DiagnosticSource": "[7.0.0, )", "System.Memory": "[4.5.5, )", diff --git a/src/Fantomas/packages.lock.json b/src/Fantomas/packages.lock.json index 6b3dea62a..b83849303 100644 --- a/src/Fantomas/packages.lock.json +++ b/src/Fantomas/packages.lock.json @@ -38,9 +38,9 @@ }, "FSharp.Core": { "type": "Direct", - "requested": "[8.0.400, )", - "resolved": "8.0.400", - "contentHash": "kHMdDDmlZl98tujgHCmL8/HNH9VKbxsRMC9s7wbwr4noR40SSa5D4d00yF8cMK52s8jabVuiLLcrUw9r+PkKDQ==" + "requested": "[6.0.1, )", + "resolved": "6.0.1", + "contentHash": "VrFAiW8dEEekk+0aqlbvMNZzDvYXmgWZwAt68AUBqaWK8RnoEVUNglj66bZzhs4/U63q0EfXlhcEKnH1sTYLjw==" }, "G-Research.FSharp.Analyzers": { "type": "Direct", @@ -898,14 +898,14 @@ "fantomas.core": { "type": "Project", "dependencies": { - "FSharp.Core": "[8.0.400, )", + "FSharp.Core": "[6.0.1, )", "Fantomas.FCS": "[1.0.0, )" } }, "fantomas.fcs": { "type": "Project", "dependencies": { - "FSharp.Core": "[8.0.400, )", + "FSharp.Core": "[6.0.1, )", "System.Collections.Immutable": "[7.0.0, )", "System.Diagnostics.DiagnosticSource": "[7.0.0, )", "System.Memory": "[4.5.5, )", From 92619f5216e9302156c7d16a450aeea8d251425d Mon Sep 17 00:00:00 2001 From: nojaf Date: Fri, 13 Sep 2024 15:33:44 +0200 Subject: [PATCH 15/20] Replace TailCall in FCS with Microsoft.FSharp.Core.TailCall --- build.fsx | 2 ++ 1 file changed, 2 insertions(+) diff --git a/build.fsx b/build.fsx index 4c4c24f4f..49be79b35 100644 --- a/build.fsx +++ b/build.fsx @@ -194,6 +194,8 @@ let updateFileRaw (file: FileInfo) = |> Array.map (fun line -> if line.Contains("FSharp.Compiler") then line.Replace("FSharp.Compiler", "Fantomas.FCS") + elif line.Contains("[]") then + line.Replace("[]", "[]") else line) File.WriteAllLines(file.FullName, updatedLines) From 433c25a021c383e244c7d9a497455ca258fdf390 Mon Sep 17 00:00:00 2001 From: nojaf Date: Fri, 13 Sep 2024 15:57:38 +0200 Subject: [PATCH 16/20] Use the static logger --- src/Fantomas/Logging.fs | 8 +++----- 1 file changed, 3 insertions(+), 5 deletions(-) diff --git a/src/Fantomas/Logging.fs b/src/Fantomas/Logging.fs index c6ebda69a..c5a4d53be 100644 --- a/src/Fantomas/Logging.fs +++ b/src/Fantomas/Logging.fs @@ -20,15 +20,13 @@ let initLogger (level: VerbosityLevel) : VerbosityLevel = Log.Logger <- logger level -let logger = Log.Logger - /// log a message -let stdlog (s: string) = logger.Information(s) +let stdlog (s: string) = Log.Logger.Information(s) /// log an error -let elog (s: string) = logger.Error(s) +let elog (s: string) = Log.Logger.Error(s) /// log a message if the verbosity level is >= Detailed -let logGrEqDetailed s = logger.Debug(s) +let logGrEqDetailed s = Log.Logger.Debug(s) let closeAndFlushLog () = Log.CloseAndFlush() From d71feaa7ee7c72c1d12fc6d05c16121b5a46bfd8 Mon Sep 17 00:00:00 2001 From: nojaf Date: Sat, 14 Sep 2024 14:05:30 +0200 Subject: [PATCH 17/20] Apply code review feedback --- src/Fantomas.Core/ASTTransformer.fs | 10 +++------- 1 file changed, 3 insertions(+), 7 deletions(-) diff --git a/src/Fantomas.Core/ASTTransformer.fs b/src/Fantomas.Core/ASTTransformer.fs index ccade4454..5dd8aff0c 100644 --- a/src/Fantomas.Core/ASTTransformer.fs +++ b/src/Fantomas.Core/ASTTransformer.fs @@ -80,8 +80,8 @@ let mkSynAccess (vis: SynAccess option) = let (|AccessSynValSigAccess|) (valSigAccess: SynValSigAccess) = match valSigAccess with - | SynValSigAccess.GetSet(accessibility = vis) - | SynValSigAccess.Single(accessibility = vis) -> vis + | SynValSigAccess.Single(accessibility = vis) + | SynValSigAccess.GetSet(accessibility = vis) -> vis let (|SynValSigAccessAll|) (valSigAccess: SynValSigAccess) = match valSigAccess with @@ -2878,16 +2878,12 @@ let mkMemberDefn (creationAide: CreationAide) (md: SynMemberDefn) = ident = ident typeOpt = typeOpt xmlDoc = px - accessibility = valSigAccess + accessibility = SynValSigAccessAll(vis, getVis, setVis) synExpr = e trivia = { LeadingKeyword = lk EqualsRange = Some mEq WithKeyword = mWith GetSetKeywords = mGS }) -> - let vis, getVis, setVis = - match valSigAccess with - | SynValSigAccess.Single(ao) -> ao, None, None - | SynValSigAccess.GetSet(ao, g, s) -> ao, g, s MemberDefnAutoPropertyNode( mkXmlDoc px, From 03412cd287b2e7a3721903197b64c0d6d1602d8e Mon Sep 17 00:00:00 2001 From: nojaf Date: Mon, 16 Sep 2024 14:01:27 +0200 Subject: [PATCH 18/20] Use trivia from Nullness --- Directory.Build.props | 2 +- src/Fantomas.Core.Tests/NullnessTests.fs | 40 +++++++++++++++++++++ src/Fantomas.Core/ASTTransformer.fs | 9 +++-- src/Fantomas.Core/CodePrinter.fs | 46 +++++++++++++++++------- src/Fantomas.Core/SyntaxOak.fs | 10 +++--- 5 files changed, 85 insertions(+), 22 deletions(-) diff --git a/Directory.Build.props b/Directory.Build.props index 41e011872..26e34508a 100644 --- a/Directory.Build.props +++ b/Directory.Build.props @@ -45,7 +45,7 @@ Some common use cases include: - 92754eb9b7076c29e19d3f6d619883b2b526c23f + e668b90e3c087e5fba8a855e502af60bf35be45e diff --git a/src/Fantomas.Core.Tests/NullnessTests.fs b/src/Fantomas.Core.Tests/NullnessTests.fs index c3adc78df..2f80450a3 100644 --- a/src/Fantomas.Core.Tests/NullnessTests.fs +++ b/src/Fantomas.Core.Tests/NullnessTests.fs @@ -108,3 +108,43 @@ namespace Meh type DU = MyCase of (string | null) """ + +[] +let ``trivia in SynType.WithNull`` () = + formatSourceString + """ +type DU = MyCase of (string + | // but why? + null) +""" + config + |> prepend newline + |> should + equal + """ +type DU = + | MyCase of + (string | // but why? + null) +""" + +[] +let ``trivia in SynTypeConstraint.WhereTyparNotSupportsNull`` () = + formatSourceString + """ +type C<'T when + 'T + : // comment 1 + not // comment 2 + null> = class end +""" + config + |> prepend newline + |> should + equal + """ +type C<'T + when 'T: // comment 1 + not // comment 2 + null> = class end +""" diff --git a/src/Fantomas.Core/ASTTransformer.fs b/src/Fantomas.Core/ASTTransformer.fs index 5dd8aff0c..93240f743 100644 --- a/src/Fantomas.Core/ASTTransformer.fs +++ b/src/Fantomas.Core/ASTTransformer.fs @@ -2181,8 +2181,8 @@ let mkSynTypeConstraint (creationAide: CreationAide) (tc: SynTypeConstraint) : T TypeConstraintEnumOrDelegateNode(mkSynTypar tp, "delegate", List.map (mkType creationAide) ts, m) |> TypeConstraint.EnumOrDelegate | SynTypeConstraint.WhereSelfConstrained(t, _) -> mkType creationAide t |> TypeConstraint.WhereSelfConstrained - | SynTypeConstraint.WhereTyparNotSupportsNull(typar, EndRange 4 (mNull, m)) -> - TypeConstraintWhereNotSupportsNull(mkSynTypar typar, stn "null" mNull, m) + | SynTypeConstraint.WhereTyparNotSupportsNull(typar, EndRange 4 (mNull, m), { ColonRange = mColon; NotRange = mNot }) -> + TypeConstraintWhereNotSupportsNull(mkSynTypar typar, stn ":" mColon, stn "not" mNot, stn "null" mNull, m) |> TypeConstraint.WhereNotSupportsNull // Arrow type is right-associative @@ -2327,11 +2327,10 @@ let mkType (creationAide: CreationAide) (t: SynType) : Type = TypeIntersectionNode(typesAndSeparators, m) |> Type.Intersection | SynType.StaticConstantNull(m) -> stn "null" m |> Type.Var // string | null - | SynType.WithNull(innerType, _, EndRange 4 (mNull, m)) -> + | SynType.WithNull(innerType, _, EndRange 4 (mNull, m), { BarRange = mBar }) -> let nullType = stn "null" mNull |> Type.Var - TypeOrNode(mkType creationAide innerType, stn "|" Range.Zero, nullType, m) - |> Type.Or + TypeOrNode(mkType creationAide innerType, stn "|" mBar, nullType, m) |> Type.Or | t -> failwith $"unexpected type: %A{t}" let rec (|OpenL|_|) = diff --git a/src/Fantomas.Core/CodePrinter.fs b/src/Fantomas.Core/CodePrinter.fs index de956ca92..720d86d59 100644 --- a/src/Fantomas.Core/CodePrinter.fs +++ b/src/Fantomas.Core/CodePrinter.fs @@ -3153,12 +3153,26 @@ let genTypeConstraint (tc: TypeConstraint) = |> genNode node | TypeConstraint.WhereSelfConstrained t -> genType t | TypeConstraint.WhereNotSupportsNull node -> - genSingleTextNode node.Typar - +> sepColon - +> !- "not" - +> sepSpace - +> genSingleTextNode node.Null - |> genNode node + let short = + genSingleTextNode node.Typar + +> onlyIfCtx (fun ctx -> ctx.Config.SpaceBeforeColon) sepSpace + +> genSingleTextNode node.Colon + +> sepSpace + +> genSingleTextNode node.Not + +> sepSpace + +> genSingleTextNode node.Null + + let long = + genSingleTextNode node.Typar + +> onlyIfCtx (fun ctx -> ctx.Config.SpaceBeforeColon) sepSpace + +> genSingleTextNode node.Colon + +> indentSepNlnUnindent ( + genSingleTextNode node.Not + +> sepNlnWhenWriteBeforeNewlineNotEmptyOr sepSpace + +> genSingleTextNode node.Null + ) + + expressionFitsOnRestOfLine short long |> genNode node let genTypeConstraints (tcs: TypeConstraint list) = let short = colPre (sepSpace +> !- "when ") wordAnd tcs genTypeConstraint @@ -3296,12 +3310,20 @@ let genType (t: Type) = +> autoIndentAndNlnIfExpressionExceedsPageWidth (genType node.Type) |> genNode node | Type.Or node -> - genType node.LeftHandSide - +> sepSpace - +> genSingleTextNode node.Or - +> sepSpace - +> genType node.RightHandSide - |> genNode node + let short = + genType node.LeftHandSide + +> sepSpace + +> genSingleTextNode node.Or + +> sepSpace + +> genType node.RightHandSide + + let long = + genType node.LeftHandSide + +> sepSpace + +> genSingleTextNode node.Or + +> indentSepNlnUnindent (genType node.RightHandSide) + + expressionFitsOnRestOfLine short long |> genNode node | Type.LongIdentApp node -> genType node.AppType +> sepDot +> genIdentListNode node.LongIdent |> genNode node diff --git a/src/Fantomas.Core/SyntaxOak.fs b/src/Fantomas.Core/SyntaxOak.fs index fe1798aa0..c15dc6f0d 100644 --- a/src/Fantomas.Core/SyntaxOak.fs +++ b/src/Fantomas.Core/SyntaxOak.fs @@ -2787,13 +2787,15 @@ type TypeConstraintEnumOrDelegateNode(typar: SingleTextNode, verb: string, ts: T member val Verb = verb member val Types = ts -type TypeConstraintWhereNotSupportsNull(typar: SingleTextNode, nullNode: SingleTextNode, range) = +/// `'T: not null` in `type C<'T when 'T: not null> = class end` +type TypeConstraintWhereNotSupportsNull + (typar: SingleTextNode, colon: SingleTextNode, notNode: SingleTextNode, nullNode: SingleTextNode, range) = inherit NodeBase(range) - override val Children: Node array = [| yield typar; yield nullNode |] - + override val Children: Node array = [| yield typar; yield colon; yield notNode; yield nullNode |] member val Typar = typar - + member val Colon = colon + member val Not = notNode member val Null = nullNode [] From 39ca6b7da6009c774692c783d8714294238698c8 Mon Sep 17 00:00:00 2001 From: nojaf Date: Mon, 16 Sep 2024 14:22:29 +0200 Subject: [PATCH 19/20] Bump tfm to net8.0 --- src/Fantomas/Fantomas.fsproj | 2 +- src/Fantomas/packages.lock.json | 16 +++++----------- 2 files changed, 6 insertions(+), 12 deletions(-) diff --git a/src/Fantomas/Fantomas.fsproj b/src/Fantomas/Fantomas.fsproj index 6210ac75a..08a87ac2b 100644 --- a/src/Fantomas/Fantomas.fsproj +++ b/src/Fantomas/Fantomas.fsproj @@ -1,7 +1,7 @@ Exe - net6.0 + net8.0 en diff --git a/src/Fantomas/packages.lock.json b/src/Fantomas/packages.lock.json index b83849303..d0d3541ea 100644 --- a/src/Fantomas/packages.lock.json +++ b/src/Fantomas/packages.lock.json @@ -1,7 +1,7 @@ { "version": 2, "dependencies": { - "net6.0": { + "net8.0": { "Argu": { "type": "Direct", "requested": "[6.2.4, )", @@ -625,8 +625,8 @@ }, "System.Runtime.CompilerServices.Unsafe": { "type": "Transitive", - "resolved": "6.0.0", - "contentHash": "/iUeP3tq1S0XdNNoMz5C9twLSrM/TH+qElHkXWaPvuNOt+99G75NrV0OS2EqHx5wMN7popYjpc8oTjC1y16DLg==" + "resolved": "4.7.1", + "contentHash": "zOHkQmzPCn5zm/BH+cxC1XbUS3P4Yoi3xzW7eRgVpDR2tPGSzyMZ17Ig1iRkfJuY0nhxkQQde8pgePNiA7z7TQ==" }, "System.Runtime.Extensions": { "type": "Transitive", @@ -928,19 +928,13 @@ "type": "CentralTransitive", "requested": "[7.0.0, )", "resolved": "7.0.0", - "contentHash": "dQPcs0U1IKnBdRDBkrCTi1FoajSTBzLcVTpjO4MBCMC7f4pDOIPzgBoX8JjG7X6uZRJ8EBxsi8+DR1JuwjnzOQ==", - "dependencies": { - "System.Runtime.CompilerServices.Unsafe": "6.0.0" - } + "contentHash": "dQPcs0U1IKnBdRDBkrCTi1FoajSTBzLcVTpjO4MBCMC7f4pDOIPzgBoX8JjG7X6uZRJ8EBxsi8+DR1JuwjnzOQ==" }, "System.Diagnostics.DiagnosticSource": { "type": "CentralTransitive", "requested": "[7.0.0, )", "resolved": "7.0.0", - "contentHash": "9W0ewWDuAyDqS2PigdTxk6jDKonfgscY/hP8hm7VpxYhNHZHKvZTdRckberlFk3VnCmr3xBUyMBut12Q+T2aOw==", - "dependencies": { - "System.Runtime.CompilerServices.Unsafe": "6.0.0" - } + "contentHash": "9W0ewWDuAyDqS2PigdTxk6jDKonfgscY/hP8hm7VpxYhNHZHKvZTdRckberlFk3VnCmr3xBUyMBut12Q+T2aOw==" }, "System.Memory": { "type": "CentralTransitive", From 0e5ccbb4d5e42b0c76df4601d3ddb9b46c6ea573 Mon Sep 17 00:00:00 2001 From: nojaf Date: Mon, 16 Sep 2024 14:27:11 +0200 Subject: [PATCH 20/20] Add first alpha changelog --- CHANGELOG.md | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index 62c59b864..356ba2f48 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,13 @@ # Changelog +## 7.0.0-alpha-001 - 2024-09-16 + +### Added +* Add initial support for Nullness syntax. [#3118](https://github.com/fsprojects/fantomas/pull/3118) + +### Changed +* Update FCS to 'Add trivia to Nullness nodes in SyntaxTree', commit 836d4e0603442d6053c8d439993a022501cae494 [#3118](https://github.com/fsprojects/fantomas/pull/3118) + ## 6.3.15 - 2024-09-14 ### Fixed