MoreEnumerable.SkipUntil<TSource> Method |
Skips items from the input sequence until the given predicate returns true
when applied to the current source item; that item will be the last skipped.
Namespace:
MoreLinq
Assembly:
MoreLinq (in MoreLinq.dll) Version: 2.2.0
Syntax public static IEnumerable<TSource> SkipUntil<TSource>(
this IEnumerable<TSource> source,
Func<TSource, bool> predicate
)
<ExtensionAttribute>
Public Shared Function SkipUntil(Of TSource) (
source As IEnumerable(Of TSource),
predicate As Func(Of TSource, Boolean)
) As IEnumerable(Of TSource)
public:
[ExtensionAttribute]
generic<typename TSource>
static IEnumerable<TSource>^ SkipUntil(
IEnumerable<TSource>^ source,
Func<TSource, bool>^ predicate
)
[<ExtensionAttribute>]
static member SkipUntil :
source : IEnumerable<'TSource> *
predicate : Func<'TSource, bool> -> IEnumerable<'TSource>
Parameters
- source
- Type: System.Collections.Generic.IEnumerable<TSource>
Source sequence - predicate
- Type: System.Func<TSource, Boolean>
Predicate used to determine when to stop yielding results from the source.
Type Parameters
- TSource
- Type of the source sequence
Return Value
Type:
IEnumerable<TSource>Items from the source sequence after the predicate first returns true when applied to the item.
Usage Note
In Visual Basic and C#, you can call this method as an instance method on any object of type
IEnumerable<TSource>. When you use instance method syntax to call this method, omit the first parameter. For more information, see
Extension Methods (Visual Basic) or
Extension Methods (C# Programming Guide).
Exceptions Remarks
SkipUntil differs from Enumerable.SkipWhile in two respects. Firstly, the sense
of the predicate is reversed: it is expected that the predicate will return false
to start with, and then return true - for example, when trying to find a matching
item in a sequence.
Secondly, SkipUntil skips the element which causes the predicate to return true. For
example, in a sequence
and with a predicate of
, the result would be
.
SkipUntil is as lazy as possible: it will not iterate over the source sequence
until it has to, it won't iterate further than it has to, and it won't evaluate
the predicate until it has to. (This means that an item may be returned which would
actually cause the predicate to throw an exception if it were evaluated, so long as
it comes after the first item causing the predicate to return true.)
See Also