// Licensed to the .NET Foundation under one or more agreements.
// The .NET Foundation licenses this file to you under the Apache 2.0 License.
// See the LICENSE file in the project root for more information.
using System.Collections.Generic;
namespace System.Linq
{
public static partial class AsyncEnumerable
{
///
/// Bypasses a specified number of elements in an async-enumerable sequence and then returns the remaining elements.
///
/// The type of the elements in the source sequence.
/// The sequence to take elements from.
/// The number of elements to skip before returning the remaining elements.
/// An async-enumerable sequence that contains the elements that occur after the specified index in the input sequence.
/// is null.
/// is less than zero.
public static IAsyncEnumerable Skip(this IAsyncEnumerable source, int count)
{
if (source == null)
throw Error.ArgumentNull(nameof(source));
if (count <= 0)
{
// Return source if not actually skipping, but only if it's a type from here, to avoid
// issues if collections are used as keys or otherwise must not be aliased.
if (source is AsyncIteratorBase || source is IAsyncPartition)
{
return source;
}
count = 0;
}
else if (source is IAsyncPartition partition)
{
return partition.Skip(count);
}
else if (source is IList list)
{
return new AsyncListPartition(list, count, int.MaxValue);
}
return new AsyncEnumerablePartition(source, count, -1);
}
}
}