From ab2e13a47c5d5f5e2a29db25b7c0a87444a584ed Mon Sep 17 00:00:00 2001 From: Atif Aziz Date: Sun, 15 Jan 2023 02:23:23 +0100 Subject: [PATCH 1/3] Use "Delegate.Comparer", retiring "Comparer" --- MoreLinq.Test/Comparer.cs | 45 ------------------------------ MoreLinq.Test/MoreLinq.Test.csproj | 1 - MoreLinq.Test/OrderByTest.cs | 3 +- MoreLinq.Test/RankTest.cs | 5 ++-- 4 files changed, 5 insertions(+), 49 deletions(-) delete mode 100644 MoreLinq.Test/Comparer.cs diff --git a/MoreLinq.Test/Comparer.cs b/MoreLinq.Test/Comparer.cs deleted file mode 100644 index 7f9f26c29..000000000 --- a/MoreLinq.Test/Comparer.cs +++ /dev/null @@ -1,45 +0,0 @@ -#region License and Terms -// MoreLINQ - Extensions to LINQ to Objects -// Copyright (c) 2017 Atif Aziz. All rights reserved. -// -// Licensed under the Apache License, Version 2.0 (the "License"); -// you may not use this file except in compliance with the License. -// You may obtain a copy of the License at -// -// http://www.apache.org/licenses/LICENSE-2.0 -// -// Unless required by applicable law or agreed to in writing, software -// distributed under the License is distributed on an "AS IS" BASIS, -// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -// See the License for the specific language governing permissions and -// limitations under the License. -#endregion - -namespace MoreLinq.Test -{ - using System; - using System.Collections.Generic; - - sealed class Comparer - { - /// - /// Creates an given a - /// . - /// - - public static IComparer Create(Func compare) => - new DelegatingComparer(compare); - - sealed class DelegatingComparer : IComparer - { - readonly Func _comparer; - - public DelegatingComparer(Func comparer) - { - _comparer = comparer ?? throw new ArgumentNullException(nameof(comparer)); - } - - public int Compare(T? x, T? y) => _comparer(x, y); - } - } -} diff --git a/MoreLinq.Test/MoreLinq.Test.csproj b/MoreLinq.Test/MoreLinq.Test.csproj index fe1ab869c..8c2a32e67 100644 --- a/MoreLinq.Test/MoreLinq.Test.csproj +++ b/MoreLinq.Test/MoreLinq.Test.csproj @@ -72,7 +72,6 @@ - diff --git a/MoreLinq.Test/OrderByTest.cs b/MoreLinq.Test/OrderByTest.cs index cb6f8bf1d..4fa256d1f 100644 --- a/MoreLinq.Test/OrderByTest.cs +++ b/MoreLinq.Test/OrderByTest.cs @@ -19,6 +19,7 @@ namespace MoreLinq.Test { using System.Collections.Generic; using NUnit.Framework; + using Delegate = Delegating.Delegate; /// /// Verify the behavior of the OrderBy/ThenBy operators @@ -47,7 +48,7 @@ public void TestOrderBySelectorPreserved() } static readonly IComparer NumericStringComparer = - Comparer.Create((string? a, string? b) => + Delegate.Comparer((string? a, string? b) => (a, b) switch { (null, null) => 0, diff --git a/MoreLinq.Test/RankTest.cs b/MoreLinq.Test/RankTest.cs index 6965c1226..13eec0194 100644 --- a/MoreLinq.Test/RankTest.cs +++ b/MoreLinq.Test/RankTest.cs @@ -19,6 +19,7 @@ namespace MoreLinq.Test { using System; using NUnit.Framework; + using Delegate = Delegating.Delegate; /// /// Verify the behavior of the Rank operator @@ -172,8 +173,8 @@ public void TestRankCustomComparer() var ordinals = Enumerable.Range(1, count); var sequence = ordinals.Select( x => new DateTime(2010,x,20-x) ); // invert the CompareTo operation to Rank in reverse order (ascending to descending) - var resultA = sequence.AsTestingSequence().Rank(Comparer.Create((a, b) => -a.CompareTo(b))); - var resultB = sequence.AsTestingSequence().RankBy(x => x.Day, Comparer.Create((a, b) => -a.CompareTo(b))); + var resultA = sequence.AsTestingSequence().Rank(Delegate.Comparer((a, b) => -a.CompareTo(b))); + var resultB = sequence.AsTestingSequence().RankBy(x => x.Day, Delegate.Comparer((a, b) => -a.CompareTo(b))); Assert.That(resultA, Is.EqualTo(ordinals)); Assert.That(resultB, Is.EqualTo(ordinals.Reverse())); From c3dfb1996d46e7db773861d8da3d56075158c41c Mon Sep 17 00:00:00 2001 From: Atif Aziz Date: Sun, 15 Jan 2023 02:39:23 +0100 Subject: [PATCH 2/3] Use comparer factory from BCL --- MoreLinq.Test/OrderByTest.cs | 3 +-- MoreLinq.Test/RankTest.cs | 6 +++--- 2 files changed, 4 insertions(+), 5 deletions(-) diff --git a/MoreLinq.Test/OrderByTest.cs b/MoreLinq.Test/OrderByTest.cs index 4fa256d1f..6e8b162e8 100644 --- a/MoreLinq.Test/OrderByTest.cs +++ b/MoreLinq.Test/OrderByTest.cs @@ -19,7 +19,6 @@ namespace MoreLinq.Test { using System.Collections.Generic; using NUnit.Framework; - using Delegate = Delegating.Delegate; /// /// Verify the behavior of the OrderBy/ThenBy operators @@ -48,7 +47,7 @@ public void TestOrderBySelectorPreserved() } static readonly IComparer NumericStringComparer = - Delegate.Comparer((string? a, string? b) => + Comparer.Create((a, b) => (a, b) switch { (null, null) => 0, diff --git a/MoreLinq.Test/RankTest.cs b/MoreLinq.Test/RankTest.cs index 13eec0194..381b8fd35 100644 --- a/MoreLinq.Test/RankTest.cs +++ b/MoreLinq.Test/RankTest.cs @@ -18,8 +18,8 @@ namespace MoreLinq.Test { using System; + using System.Collections.Generic; using NUnit.Framework; - using Delegate = Delegating.Delegate; /// /// Verify the behavior of the Rank operator @@ -173,8 +173,8 @@ public void TestRankCustomComparer() var ordinals = Enumerable.Range(1, count); var sequence = ordinals.Select( x => new DateTime(2010,x,20-x) ); // invert the CompareTo operation to Rank in reverse order (ascending to descending) - var resultA = sequence.AsTestingSequence().Rank(Delegate.Comparer((a, b) => -a.CompareTo(b))); - var resultB = sequence.AsTestingSequence().RankBy(x => x.Day, Delegate.Comparer((a, b) => -a.CompareTo(b))); + var resultA = sequence.AsTestingSequence().Rank(Comparer.Create((a, b) => -a.CompareTo(b))); + var resultB = sequence.AsTestingSequence().RankBy(x => x.Day, Comparer.Create((a, b) => -a.CompareTo(b))); Assert.That(resultA, Is.EqualTo(ordinals)); Assert.That(resultB, Is.EqualTo(ordinals.Reverse())); From d625bcd12fa81dcd79aae30028f48303185b601f Mon Sep 17 00:00:00 2001 From: Atif Aziz Date: Sun, 15 Jan 2023 02:47:22 +0100 Subject: [PATCH 3/3] Remove null cases from "NumericStringComparer" --- MoreLinq.Test/OrderByTest.cs | 9 +-------- 1 file changed, 1 insertion(+), 8 deletions(-) diff --git a/MoreLinq.Test/OrderByTest.cs b/MoreLinq.Test/OrderByTest.cs index 6e8b162e8..f8f06a2ce 100644 --- a/MoreLinq.Test/OrderByTest.cs +++ b/MoreLinq.Test/OrderByTest.cs @@ -47,14 +47,7 @@ public void TestOrderBySelectorPreserved() } static readonly IComparer NumericStringComparer = - Comparer.Create((a, b) => - (a, b) switch - { - (null, null) => 0, - (null, _) => -1, - (_, null) => 1, - var (sa, sb) => int.Parse(sa).CompareTo(int.Parse(sb)) - }); + Comparer.Create((a, b) => int.Parse(a).CompareTo(int.Parse(b))); /// /// Verify that OrderBy preserves the comparer