| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560 | // Licensed to the .NET Foundation under one or more agreements.// The .NET Foundation licenses this file to you under the MIT License.// See the LICENSE file in the project root for more information. using System.Collections.Generic;namespace System.Reactive.Linq{    public static partial class Observable    {        #region + Chunkify +        /// <summary>        /// Produces an enumerable sequence of consecutive (possibly empty) chunks of the source sequence.        /// </summary>        /// <typeparam name="TSource">The type of the elements in the source sequence.</typeparam>        /// <param name="source">Source observable sequence.</param>        /// <returns>The enumerable sequence that returns consecutive (possibly empty) chunks upon each iteration.</returns>        /// <exception cref="ArgumentNullException"><paramref name="source"/> is null.</exception>        public static IEnumerable<IList<TSource>> Chunkify<TSource>(this IObservable<TSource> source)        {            if (source == null)            {                throw new ArgumentNullException(nameof(source));            }            return s_impl.Chunkify(source);        }        #endregion        #region + Collect +        /// <summary>        /// Produces an enumerable sequence that returns elements collected/aggregated from the source sequence between consecutive iterations.        /// </summary>        /// <typeparam name="TSource">The type of the elements in the source sequence.</typeparam>        /// <typeparam name="TResult">The type of the elements produced by the merge operation during collection.</typeparam>        /// <param name="source">Source observable sequence.</param>        /// <param name="newCollector">Factory to create a new collector object.</param>        /// <param name="merge">Merges a sequence element with the current collector.</param>        /// <returns>The enumerable sequence that returns collected/aggregated elements from the source sequence upon each iteration.</returns>        /// <exception cref="ArgumentNullException"><paramref name="source"/> or <paramref name="newCollector"/> or <paramref name="merge"/> is null.</exception>        public static IEnumerable<TResult> Collect<TSource, TResult>(this IObservable<TSource> source, Func<TResult> newCollector, Func<TResult, TSource, TResult> merge)        {            if (source == null)            {                throw new ArgumentNullException(nameof(source));            }            if (newCollector == null)            {                throw new ArgumentNullException(nameof(newCollector));            }            if (merge == null)            {                throw new ArgumentNullException(nameof(merge));            }            return s_impl.Collect(source, newCollector, merge);        }        /// <summary>        /// Produces an enumerable sequence that returns elements collected/aggregated from the source sequence between consecutive iterations.        /// </summary>        /// <typeparam name="TSource">The type of the elements in the source sequence.</typeparam>        /// <typeparam name="TResult">The type of the elements produced by the merge operation during collection.</typeparam>        /// <param name="source">Source observable sequence.</param>        /// <param name="getInitialCollector">Factory to create the initial collector object.</param>        /// <param name="merge">Merges a sequence element with the current collector.</param>        /// <param name="getNewCollector">Factory to replace the current collector by a new collector.</param>        /// <returns>The enumerable sequence that returns collected/aggregated elements from the source sequence upon each iteration.</returns>        /// <exception cref="ArgumentNullException"><paramref name="source"/> or <paramref name="getInitialCollector"/> or <paramref name="merge"/> or <paramref name="getNewCollector"/> is null.</exception>        public static IEnumerable<TResult> Collect<TSource, TResult>(this IObservable<TSource> source, Func<TResult> getInitialCollector, Func<TResult, TSource, TResult> merge, Func<TResult, TResult> getNewCollector)        {            if (source == null)            {                throw new ArgumentNullException(nameof(source));            }            if (getInitialCollector == null)            {                throw new ArgumentNullException(nameof(getInitialCollector));            }            if (merge == null)            {                throw new ArgumentNullException(nameof(merge));            }            if (getNewCollector == null)            {                throw new ArgumentNullException(nameof(getNewCollector));            }            return s_impl.Collect(source, getInitialCollector, merge, getNewCollector);        }        #endregion        #region + First +        /// <summary>        /// Returns the first element of an observable sequence.        /// </summary>        /// <typeparam name="TSource">The type of the elements in the source sequence.</typeparam>        /// <param name="source">Source observable sequence.</param>        /// <returns>The first element in the observable sequence.</returns>        /// <exception cref="ArgumentNullException"><paramref name="source"/> is null.</exception>        /// <exception cref="InvalidOperationException">The source sequence is empty.</exception>        /// <seealso cref="Observable.FirstAsync{TSource}(IObservable{TSource})"/>        [Obsolete(Constants_Linq.UseAsync)]        public static TSource First<TSource>(this IObservable<TSource> source)        {            if (source == null)            {                throw new ArgumentNullException(nameof(source));            }            return s_impl.First(source);        }        /// <summary>        /// Returns the first element of an observable sequence that satisfies the condition in the predicate.        /// </summary>        /// <typeparam name="TSource">The type of the elements in the source sequence.</typeparam>        /// <param name="source">Source observable sequence.</param>        /// <param name="predicate">A predicate function to evaluate for elements in the source sequence.</param>        /// <returns>The first element in the observable sequence that satisfies the condition in the predicate.</returns>        /// <exception cref="ArgumentNullException"><paramref name="source"/> or <paramref name="predicate"/> is null.</exception>        /// <exception cref="InvalidOperationException">No element satisfies the condition in the predicate. -or- The source sequence is empty.</exception>        /// <seealso cref="Observable.FirstAsync{TSource}(IObservable{TSource}, Func{TSource, bool})"/>        [Obsolete(Constants_Linq.UseAsync)]        public static TSource First<TSource>(this IObservable<TSource> source, Func<TSource, bool> predicate)        {            if (source == null)            {                throw new ArgumentNullException(nameof(source));            }            if (predicate == null)            {                throw new ArgumentNullException(nameof(predicate));            }            return s_impl.First(source, predicate);        }        #endregion        #region + FirstOrDefault +        /// <summary>        /// Returns the first element of an observable sequence, or a default value if no such element exists.        /// </summary>        /// <typeparam name="TSource">The type of the elements in the source sequence.</typeparam>        /// <param name="source">Source observable sequence.</param>        /// <returns>The first element in the observable sequence, or a default value if no such element exists.</returns>        /// <exception cref="ArgumentNullException"><paramref name="source"/> is null.</exception>        /// <seealso cref="Observable.FirstOrDefaultAsync{TSource}(IObservable{TSource})"/>        [Obsolete(Constants_Linq.UseAsync)]        public static TSource FirstOrDefault<TSource>(this IObservable<TSource> source)        {            if (source == null)            {                throw new ArgumentNullException(nameof(source));            }            return s_impl.FirstOrDefault(source);        }        /// <summary>        /// Returns the first element of an observable sequence that satisfies the condition in the predicate, or a default value if no such element exists.        /// </summary>        /// <typeparam name="TSource">The type of the elements in the source sequence.</typeparam>        /// <param name="source">Source observable sequence.</param>        /// <param name="predicate">A predicate function to evaluate for elements in the source sequence.</param>        /// <returns>The first element in the observable sequence that satisfies the condition in the predicate, or a default value if no such element exists.</returns>        /// <exception cref="ArgumentNullException"><paramref name="source"/> or <paramref name="predicate"/> is null.</exception>        /// <seealso cref="Observable.FirstOrDefaultAsync{TSource}(IObservable{TSource}, Func{TSource, bool})"/>        [Obsolete(Constants_Linq.UseAsync)]        public static TSource FirstOrDefault<TSource>(this IObservable<TSource> source, Func<TSource, bool> predicate)        {            if (source == null)            {                throw new ArgumentNullException(nameof(source));            }            if (predicate == null)            {                throw new ArgumentNullException(nameof(predicate));            }            return s_impl.FirstOrDefault(source, predicate);        }        #endregion        #region + ForEach +        /// <summary>        /// Invokes an action for each element in the observable sequence, and blocks until the sequence is terminated.        /// </summary>        /// <typeparam name="TSource">The type of the elements in the source sequence.</typeparam>        /// <param name="source">Source sequence.</param>        /// <param name="onNext">Action to invoke for each element in the observable sequence.</param>        /// <exception cref="ArgumentNullException"><paramref name="source"/> or <paramref name="onNext"/> is null.</exception>        /// <remarks>Because of its blocking nature, this operator is mainly used for testing.</remarks>        [Obsolete(Constants_Linq.UseAsync)]        public static void ForEach<TSource>(this IObservable<TSource> source, Action<TSource> onNext)        {            if (source == null)            {                throw new ArgumentNullException(nameof(source));            }            if (onNext == null)            {                throw new ArgumentNullException(nameof(onNext));            }            s_impl.ForEach(source, onNext);        }        /// <summary>        /// Invokes an action for each element in the observable sequence, incorporating the element's index, and blocks until the sequence is terminated.        /// </summary>        /// <typeparam name="TSource">The type of the elements in the source sequence.</typeparam>        /// <param name="source">Source sequence.</param>        /// <param name="onNext">Action to invoke for each element in the observable sequence.</param>        /// <exception cref="ArgumentNullException"><paramref name="source"/> or <paramref name="onNext"/> is null.</exception>        /// <remarks>Because of its blocking nature, this operator is mainly used for testing.</remarks>        [Obsolete(Constants_Linq.UseAsync)]        public static void ForEach<TSource>(this IObservable<TSource> source, Action<TSource, int> onNext)        {            if (source == null)            {                throw new ArgumentNullException(nameof(source));            }            if (onNext == null)            {                throw new ArgumentNullException(nameof(onNext));            }            s_impl.ForEach(source, onNext);        }        #endregion        #region + GetEnumerator +        /// <summary>        /// Returns an enumerator that enumerates all values of the observable sequence.        /// </summary>        /// <typeparam name="TSource">The type of the elements in the source sequence.</typeparam>        /// <param name="source">An observable sequence to get an enumerator for.</param>        /// <returns>The enumerator that can be used to enumerate over the elements in the observable sequence.</returns>        /// <exception cref="ArgumentNullException"><paramref name="source"/> is null.</exception>        public static IEnumerator<TSource> GetEnumerator<TSource>(this IObservable<TSource> source)        {            if (source == null)            {                throw new ArgumentNullException(nameof(source));            }            return s_impl.GetEnumerator(source);        }        #endregion        #region + Last +        /// <summary>        /// Returns the last element of an observable sequence.        /// </summary>        /// <typeparam name="TSource">The type of the elements in the source sequence.</typeparam>        /// <param name="source">Source observable sequence.</param>        /// <returns>The last element in the observable sequence.</returns>        /// <exception cref="ArgumentNullException"><paramref name="source"/> is null.</exception>        /// <exception cref="InvalidOperationException">The source sequence is empty.</exception>        /// <seealso cref="Observable.LastAsync{TSource}(IObservable{TSource})"/>        [Obsolete(Constants_Linq.UseAsync)]        public static TSource Last<TSource>(this IObservable<TSource> source)        {            if (source == null)            {                throw new ArgumentNullException(nameof(source));            }            return s_impl.Last(source);        }        /// <summary>        /// Returns the last element of an observable sequence that satisfies the condition in the predicate.        /// </summary>        /// <typeparam name="TSource">The type of the elements in the source sequence.</typeparam>        /// <param name="source">Source observable sequence.</param>        /// <param name="predicate">A predicate function to evaluate for elements in the source sequence.</param>        /// <returns>The last element in the observable sequence that satisfies the condition in the predicate.</returns>        /// <exception cref="ArgumentNullException"><paramref name="source"/> or <paramref name="predicate"/> is null.</exception>        /// <exception cref="InvalidOperationException">No element satisfies the condition in the predicate. -or- The source sequence is empty.</exception>        /// <seealso cref="Observable.LastAsync{TSource}(IObservable{TSource}, Func{TSource, bool})"/>        [Obsolete(Constants_Linq.UseAsync)]        public static TSource Last<TSource>(this IObservable<TSource> source, Func<TSource, bool> predicate)        {            if (source == null)            {                throw new ArgumentNullException(nameof(source));            }            if (predicate == null)            {                throw new ArgumentNullException(nameof(predicate));            }            return s_impl.Last(source, predicate);        }        #endregion        #region + LastOrDefault +        /// <summary>        /// Returns the last element of an observable sequence, or a default value if no such element exists.        /// </summary>        /// <typeparam name="TSource">The type of the elements in the source sequence.</typeparam>        /// <param name="source">Source observable sequence.</param>        /// <returns>The last element in the observable sequence, or a default value if no such element exists.</returns>        /// <exception cref="ArgumentNullException"><paramref name="source"/> is null.</exception>        /// <seealso cref="Observable.LastOrDefaultAsync{TSource}(IObservable{TSource})"/>        [Obsolete(Constants_Linq.UseAsync)]        public static TSource LastOrDefault<TSource>(this IObservable<TSource> source)        {            if (source == null)            {                throw new ArgumentNullException(nameof(source));            }            return s_impl.LastOrDefault(source);        }        /// <summary>        /// Returns the last element of an observable sequence that satisfies the condition in the predicate, or a default value if no such element exists.        /// </summary>        /// <typeparam name="TSource">The type of the elements in the source sequence.</typeparam>        /// <param name="source">Source observable sequence.</param>        /// <param name="predicate">A predicate function to evaluate for elements in the source sequence.</param>        /// <returns>The last element in the observable sequence that satisfies the condition in the predicate, or a default value if no such element exists.</returns>        /// <exception cref="ArgumentNullException"><paramref name="source"/> or <paramref name="predicate"/> is null.</exception>        /// <seealso cref="Observable.LastOrDefaultAsync{TSource}(IObservable{TSource}, Func{TSource, bool})"/>        [Obsolete(Constants_Linq.UseAsync)]        public static TSource LastOrDefault<TSource>(this IObservable<TSource> source, Func<TSource, bool> predicate)        {            if (source == null)            {                throw new ArgumentNullException(nameof(source));            }            if (predicate == null)            {                throw new ArgumentNullException(nameof(predicate));            }            return s_impl.LastOrDefault(source, predicate);        }        #endregion        #region + Latest +        /// <summary>        /// Returns an enumerable sequence whose enumeration returns the latest observed element in the source observable sequence.        /// Enumerators on the resulting sequence will never produce the same element repeatedly, and will block until the next element becomes available.        /// </summary>        /// <typeparam name="TSource">The type of the elements in the source sequence.</typeparam>        /// <param name="source">Source observable sequence.</param>        /// <returns>The enumerable sequence that returns the last sampled element upon each iteration and subsequently blocks until the next element in the observable source sequence becomes available.</returns>        public static IEnumerable<TSource> Latest<TSource>(this IObservable<TSource> source)        {            if (source == null)            {                throw new ArgumentNullException(nameof(source));            }            return s_impl.Latest(source);        }        #endregion        #region + MostRecent +        /// <summary>        /// Returns an enumerable sequence whose enumeration returns the most recently observed element in the source observable sequence, using the specified initial value in case no element has been sampled yet.        /// Enumerators on the resulting sequence never block and can produce the same element repeatedly.        /// </summary>        /// <typeparam name="TSource">The type of the elements in the source sequence.</typeparam>        /// <param name="source">Source observable sequence.</param>        /// <param name="initialValue">Initial value that will be yielded by the enumerable sequence if no element has been sampled yet.</param>        /// <returns>The enumerable sequence that returns the last sampled element upon each iteration.</returns>        /// <exception cref="ArgumentNullException"><paramref name="source"/> is null.</exception>        public static IEnumerable<TSource> MostRecent<TSource>(this IObservable<TSource> source, TSource initialValue)        {            if (source == null)            {                throw new ArgumentNullException(nameof(source));            }            return s_impl.MostRecent(source, initialValue);        }        #endregion        #region + Next +        /// <summary>        /// Returns an enumerable sequence whose enumeration blocks until the next element in the source observable sequence becomes available.        /// Enumerators on the resulting sequence will block until the next element becomes available.        /// </summary>        /// <typeparam name="TSource">The type of the elements in the source sequence.</typeparam>        /// <param name="source">Source observable sequence.</param>        /// <returns>The enumerable sequence that blocks upon each iteration until the next element in the observable source sequence becomes available.</returns>        /// <exception cref="ArgumentNullException"><paramref name="source"/> is null.</exception>        public static IEnumerable<TSource> Next<TSource>(this IObservable<TSource> source)        {            if (source == null)            {                throw new ArgumentNullException(nameof(source));            }            return s_impl.Next(source);        }        #endregion        #region + Single +        /// <summary>        /// Returns the only element of an observable sequence, and throws an exception if there is not exactly one element in the observable sequence.        /// </summary>        /// <typeparam name="TSource">The type of the elements in the source sequence.</typeparam>        /// <param name="source">Source observable sequence.</param>        /// <returns>The single element in the observable sequence.</returns>        /// <exception cref="ArgumentNullException"><paramref name="source"/> is null.</exception>        /// <exception cref="InvalidOperationException">The source sequence contains more than one element. -or- The source sequence is empty.</exception>        /// <seealso cref="Observable.SingleAsync{TSource}(IObservable{TSource})"/>        [Obsolete(Constants_Linq.UseAsync)]        public static TSource Single<TSource>(this IObservable<TSource> source)        {            if (source == null)            {                throw new ArgumentNullException(nameof(source));            }            return s_impl.Single(source);        }        /// <summary>        /// Returns the only element of an observable sequence that satisfies the condition in the predicate, and throws an exception if there is not exactly one element matching the predicate in the observable sequence.        /// </summary>        /// <typeparam name="TSource">The type of the elements in the source sequence.</typeparam>        /// <param name="source">Source observable sequence.</param>        /// <param name="predicate">A predicate function to evaluate for elements in the source sequence.</param>        /// <returns>The single element in the observable sequence that satisfies the condition in the predicate.</returns>        /// <exception cref="ArgumentNullException"><paramref name="source"/> or <paramref name="predicate"/> is null.</exception>        /// <exception cref="InvalidOperationException">No element satisfies the condition in the predicate. -or- More than one element satisfies the condition in the predicate. -or- The source sequence is empty.</exception>        /// <seealso cref="Observable.SingleAsync{TSource}(IObservable{TSource}, Func{TSource, bool})"/>        [Obsolete(Constants_Linq.UseAsync)]        public static TSource Single<TSource>(this IObservable<TSource> source, Func<TSource, bool> predicate)        {            if (source == null)            {                throw new ArgumentNullException(nameof(source));            }            if (predicate == null)            {                throw new ArgumentNullException(nameof(predicate));            }            return s_impl.Single(source, predicate);        }        #endregion        #region + SingleOrDefault +        /// <summary>        /// Returns the only element of an observable sequence, or a default value if the observable sequence is empty; this method throws an exception if there is more than one element in the observable sequence.        /// </summary>        /// <typeparam name="TSource">The type of the elements in the source sequence.</typeparam>        /// <param name="source">Source observable sequence.</param>        /// <returns>The single element in the observable sequence, or a default value if no such element exists.</returns>        /// <exception cref="ArgumentNullException"><paramref name="source"/> is null.</exception>        /// <exception cref="InvalidOperationException">The source sequence contains more than one element.</exception>        /// <seealso cref="Observable.SingleOrDefaultAsync{TSource}(IObservable{TSource})"/>        [Obsolete(Constants_Linq.UseAsync)]        public static TSource SingleOrDefault<TSource>(this IObservable<TSource> source)        {            if (source == null)            {                throw new ArgumentNullException(nameof(source));            }            return s_impl.SingleOrDefault(source);        }        /// <summary>        /// Returns the only element of an observable sequence that satisfies the condition in the predicate, or a default value if no such element exists; this method throws an exception if there is more than one element matching the predicate in the observable sequence.        /// </summary>        /// <typeparam name="TSource">The type of the elements in the source sequence.</typeparam>        /// <param name="source">Source observable sequence.</param>        /// <param name="predicate">A predicate function to evaluate for elements in the source sequence.</param>        /// <returns>The single element in the observable sequence that satisfies the condition in the predicate, or a default value if no such element exists.</returns>        /// <exception cref="ArgumentNullException"><paramref name="source"/> or <paramref name="predicate"/> is null.</exception>        /// <exception cref="InvalidOperationException">The sequence contains more than one element that satisfies the condition in the predicate.</exception>        /// <seealso cref="Observable.SingleOrDefaultAsync{TSource}(IObservable{TSource}, Func{TSource, bool})"/>        [Obsolete(Constants_Linq.UseAsync)]        public static TSource SingleOrDefault<TSource>(this IObservable<TSource> source, Func<TSource, bool> predicate)        {            if (source == null)            {                throw new ArgumentNullException(nameof(source));            }            if (predicate == null)            {                throw new ArgumentNullException(nameof(predicate));            }            return s_impl.SingleOrDefault(source, predicate);        }        #endregion        #region + Wait +        /// <summary>        /// Waits for the observable sequence to complete and returns the last element of the sequence.        /// If the sequence terminates with an OnError notification, the exception is thrown.        /// </summary>        /// <typeparam name="TSource">The type of the elements in the source sequence.</typeparam>        /// <param name="source">Source observable sequence.</param>        /// <returns>The last element in the observable sequence.</returns>        /// <exception cref="ArgumentNullException"><paramref name="source"/> is null.</exception>        /// <exception cref="InvalidOperationException">The source sequence is empty.</exception>        public static TSource Wait<TSource>(this IObservable<TSource> source)        {            if (source == null)            {                throw new ArgumentNullException(nameof(source));            }            return s_impl.Wait(source);        }        #endregion    }}
 |