Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Use LinkedList in Interleave to avoid many null checks #726

Merged
merged 24 commits into from
Jan 14, 2023
Merged
Changes from 1 commit
Commits
Show all changes
24 commits
Select commit Hold shift + click to select a range
c9aa710
Add TestInterleaveDoNoCallMoveNextEagerly.
Orace Nov 14, 2019
66d1228
Fix interleave implementation so it doen't call MoveNext eagerly.
Orace Nov 14, 2019
336423a
Update MoreLinq/Interleave.cs
Orace Nov 14, 2019
61e4921
Fix the test
atifaziz Nov 22, 2019
b790e53
Undo implementation to prove test isn't bokren
atifaziz Nov 22, 2019
c569479
Merge branch 'master' into issue694
atifaziz Nov 22, 2019
32f02e4
Add TestInterleaveDoNoCallMoveNextEagerly.
Orace Nov 14, 2019
6ff6d03
Fix interleave implementation so it doen't call MoveNext eagerly.
Orace Nov 14, 2019
8a972a9
Merge back originally proposed fix and test
atifaziz Nov 22, 2019
1a4270f
Interleave: add early test of null elements in otherSequences
Orace Nov 22, 2019
76e3516
Added TestInterleaveEarlyThrowOnNullElementInOtherSequences
Orace Nov 22, 2019
6f61760
Remove useless private extension method
Orace Nov 22, 2019
81479fb
Added TestInterleaveDisposesOnPartialEnumeration
Orace Nov 25, 2019
00ef366
Made TestInterleaveDisposesOnPartialEnumeration pass
Orace Nov 25, 2019
d70974b
Interleave: simple implementation using Acquire.
Orace Nov 25, 2019
9be11ad
remove trailing whitespaces
Orace Nov 25, 2019
08f7d20
Merge branch 'issue694' into ImproveInterleave
Orace Nov 25, 2019
7cc48f8
Merge remote-tracking branch 'upstream/master' into ImproveInterleave
atifaziz Jan 14, 2023
15d0da9
Dispose enumerator if first move fails
atifaziz Jan 14, 2023
3faa3bf
Improve comments
atifaziz Jan 14, 2023
31611f3
Use pattern matching on node
atifaziz Jan 14, 2023
6eb13c4
Remove redundant modifier
atifaziz Jan 14, 2023
f78c19d
Remove "Skip" suffix from iterator method name
atifaziz Jan 14, 2023
5314fb3
Convert core iterator into local function
atifaziz Jan 14, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Merge remote-tracking branch 'upstream/master' into ImproveInterleave
Conflicts resolved:

- MoreLinq.Test/InterleaveTest.cs
- MoreLinq/Interleave.cs
atifaziz committed Jan 14, 2023

Unverified

This commit is not signed, but one or more authors requires that any commit attributed to them is signed.
commit 7cc48f8b82ae14ec0812c1cdc37bdb2cbc204206
54 changes: 0 additions & 54 deletions MoreLinq.Test/InterleaveTest.cs
Original file line number Diff line number Diff line change
@@ -17,8 +17,6 @@

namespace MoreLinq.Test
{
using System;
using System.Collections.Generic;
using NUnit.Framework;

/// <summary>
@@ -36,41 +34,6 @@ public void TestInterleaveIsLazy()
new BreakingSequence<int>().Interleave(new BreakingSequence<int>());
}

/// <summary>
/// Verify that Interleave early throw ArgumentNullException when an element
/// of otherSequences is null.
/// </summary>
[Test]
public void TestInterleaveEarlyThrowOnNullElementInOtherSequences()
{
void Code()
{
var sequenceA = Enumerable.Range(1, 1);
var otherSequences = new IEnumerable<int>[] {null};

sequenceA.Interleave(otherSequences);
}

Assert.Throws<ArgumentNullException>(Code);
}

/// <summary>
/// Verify that interleaving do not call enumerators MoveNext method eagerly
/// </summary>
[Test]
public void TestInterleaveDoNoCallMoveNextEagerly()
{
void Code()
{
var sequenceA = Enumerable.Range(1, 1);
var sequenceB = MoreEnumerable.From<int>(() => throw new TestException());

sequenceA.Interleave(sequenceB).Take(1).Consume();
}

Assert.DoesNotThrow(Code);
}

/// <summary>
/// Verify that interleaving disposes those enumerators that it managed
/// to open successfully
@@ -125,23 +88,6 @@ public void TestInterleaveDoNoCallMoveNextEagerly()
sequenceA.Interleave(sequenceB).Take(1).Consume();
}

/// <summary>
/// Verify that, in case of partial enumeration, interleaving disposes those
/// enumerators that it managed to open successfully
/// </summary>
[TestCase(0)]
[TestCase(1)]
[TestCase(2)]
[TestCase(3)]
public void TestInterleaveDisposesOnPartialEnumeration(int count)
{
using var sequenceA = TestingSequence.Of<int>(1);
using var sequenceB = TestingSequence.Of<int>(2);
using var sequenceC = TestingSequence.Of<int>(3);

sequenceA.Interleave(sequenceB, sequenceC).Take(count).Consume();
}

/// <summary>
/// Verify that two balanced sequences will interleave all of their elements
/// </summary>
You are viewing a condensed version of this merge commit. You can view the full changes here.