// 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); } } }