| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624 | // Copyright (c) Microsoft Open Technologies, Inc. All rights reserved. See License.txt in the project root for license information.using System.Collections.Generic;using System.Reactive.Concurrency;using System.Threading;#if !NO_TPLusing System.Threading.Tasks;#endifnamespace System.Reactive.Linq{    public static partial class Observable    {        #region + Create +        /// <summary>        /// Creates an observable sequence from a specified Subscribe method implementation.        /// </summary>        /// <typeparam name="TResult">The type of the elements in the produced sequence.</typeparam>        /// <param name="subscribe">Implementation of the resulting observable sequence's Subscribe method.</param>        /// <returns>The observable sequence with the specified implementation for the Subscribe method.</returns>        /// <exception cref="ArgumentNullException"><paramref name="subscribe"/> is null.</exception>        /// <remarks>        /// Use of this operator is preferred over manual implementation of the IObservable<T> interface. In case        /// you need a type implementing IObservable<T> rather than an anonymous implementation, consider using        /// the <see cref="System.Reactive.ObservableBase<T>"/> abstract base class.        /// </remarks>        public static IObservable<TResult> Create<TResult>(Func<IObserver<TResult>, IDisposable> subscribe)        {            if (subscribe == null)                throw new ArgumentNullException("subscribe");            return s_impl.Create<TResult>(subscribe);        }        /// <summary>        /// Creates an observable sequence from a specified Subscribe method implementation.        /// </summary>        /// <typeparam name="TResult">The type of the elements in the produced sequence.</typeparam>        /// <param name="subscribe">Implementation of the resulting observable sequence's Subscribe method, returning an Action delegate that will be wrapped in an IDisposable.</param>        /// <returns>The observable sequence with the specified implementation for the Subscribe method.</returns>        /// <exception cref="ArgumentNullException"><paramref name="subscribe"/> is null.</exception>        /// <remarks>        /// Use of this operator is preferred over manual implementation of the IObservable<T> interface. In case        /// you need a type implementing IObservable<T> rather than an anonymous implementation, consider using        /// the <see cref="System.Reactive.ObservableBase<T>"/> abstract base class.        /// </remarks>        public static IObservable<TResult> Create<TResult>(Func<IObserver<TResult>, Action> subscribe)        {            if (subscribe == null)                throw new ArgumentNullException("subscribe");            return s_impl.Create<TResult>(subscribe);        }        #endregion        #region + CreateAsync +#if !NO_TPL        /// <summary>        /// Creates an observable sequence from a specified cancellable asynchronous Subscribe method.        /// The CancellationToken passed to the asynchronous Subscribe method is tied to the returned disposable subscription, allowing best-effort cancellation.        /// </summary>        /// <typeparam name="TResult">The type of the elements in the produced sequence.</typeparam>        /// <param name="subscribeAsync">Asynchronous method used to produce elements.</param>        /// <returns>The observable sequence surfacing the elements produced by the asynchronous method.</returns>        /// <exception cref="ArgumentNullException"><paramref name="subscribeAsync"/> is null.</exception>        /// <remarks>This operator is especially useful in conjunction with the asynchronous programming features introduced in C# 5.0 and Visual Basic 11.</remarks>        /// <remarks>When a subscription to the resulting sequence is disposed, the CancellationToken that was fed to the asynchronous subscribe function will be signaled.</remarks>        public static IObservable<TResult> Create<TResult>(Func<IObserver<TResult>, CancellationToken, Task> subscribeAsync)        {            if (subscribeAsync == null)                throw new ArgumentNullException("subscribeAsync");            return s_impl.Create<TResult>(subscribeAsync);        }        /// <summary>        /// Creates an observable sequence from a specified asynchronous Subscribe method.        /// </summary>        /// <typeparam name="TResult">The type of the elements in the produced sequence.</typeparam>        /// <param name="subscribeAsync">Asynchronous method used to produce elements.</param>        /// <returns>The observable sequence surfacing the elements produced by the asynchronous method.</returns>        /// <exception cref="ArgumentNullException"><paramref name="subscribeAsync"/> is null.</exception>        /// <remarks>This operator is especially useful in conjunction with the asynchronous programming features introduced in C# 5.0 and Visual Basic 11.</remarks>        public static IObservable<TResult> Create<TResult>(Func<IObserver<TResult>, Task> subscribeAsync)        {            if (subscribeAsync == null)                throw new ArgumentNullException("subscribeAsync");            return s_impl.Create<TResult>(subscribeAsync);        }        /// <summary>        /// Creates an observable sequence from a specified cancellable asynchronous Subscribe method.        /// The CancellationToken passed to the asynchronous Subscribe method is tied to the returned disposable subscription, allowing best-effort cancellation.        /// </summary>        /// <typeparam name="TResult">The type of the elements in the produced sequence.</typeparam>        /// <param name="subscribeAsync">Asynchronous method used to implemented the resulting sequence's Subscribe method.</param>        /// <returns>The observable sequence with the specified implementation for the Subscribe method.</returns>        /// <exception cref="ArgumentNullException"><paramref name="subscribeAsync"/> is null.</exception>        /// <remarks>This operator is especially useful in conjunction with the asynchronous programming features introduced in C# 5.0 and Visual Basic 11.</remarks>        /// <remarks>When a subscription to the resulting sequence is disposed, the CancellationToken that was fed to the asynchronous subscribe function will be signaled.</remarks>        public static IObservable<TResult> Create<TResult>(Func<IObserver<TResult>, CancellationToken, Task<IDisposable>> subscribeAsync)        {            if (subscribeAsync == null)                throw new ArgumentNullException("subscribeAsync");            return s_impl.Create<TResult>(subscribeAsync);        }        /// <summary>        /// Creates an observable sequence from a specified asynchronous Subscribe method.        /// </summary>        /// <typeparam name="TResult">The type of the elements in the produced sequence.</typeparam>        /// <param name="subscribeAsync">Asynchronous method used to implemented the resulting sequence's Subscribe method.</param>        /// <returns>The observable sequence with the specified implementation for the Subscribe method.</returns>        /// <exception cref="ArgumentNullException"><paramref name="subscribeAsync"/> is null.</exception>        /// <remarks>This operator is especially useful in conjunction with the asynchronous programming features introduced in C# 5.0 and Visual Basic 11.</remarks>        public static IObservable<TResult> Create<TResult>(Func<IObserver<TResult>, Task<IDisposable>> subscribeAsync)        {            if (subscribeAsync == null)                throw new ArgumentNullException("subscribeAsync");            return s_impl.Create<TResult>(subscribeAsync);        }        /// <summary>        /// Creates an observable sequence from a specified cancellable asynchronous Subscribe method.        /// The CancellationToken passed to the asynchronous Subscribe method is tied to the returned disposable subscription, allowing best-effort cancellation.        /// </summary>        /// <typeparam name="TResult">The type of the elements in the produced sequence.</typeparam>        /// <param name="subscribeAsync">Asynchronous method used to implemented the resulting sequence's Subscribe method, returning an Action delegate that will be wrapped in an IDisposable.</param>        /// <returns>The observable sequence with the specified implementation for the Subscribe method.</returns>        /// <exception cref="ArgumentNullException"><paramref name="subscribeAsync"/> is null.</exception>        /// <remarks>This operator is especially useful in conjunction with the asynchronous programming features introduced in C# 5.0 and Visual Basic 11.</remarks>        /// <remarks>When a subscription to the resulting sequence is disposed, the CancellationToken that was fed to the asynchronous subscribe function will be signaled.</remarks>        public static IObservable<TResult> Create<TResult>(Func<IObserver<TResult>, CancellationToken, Task<Action>> subscribeAsync)        {            if (subscribeAsync == null)                throw new ArgumentNullException("subscribeAsync");            return s_impl.Create<TResult>(subscribeAsync);        }        /// <summary>        /// Creates an observable sequence from a specified asynchronous Subscribe method.        /// </summary>        /// <typeparam name="TResult">The type of the elements in the produced sequence.</typeparam>        /// <param name="subscribeAsync">Asynchronous method used to implemented the resulting sequence's Subscribe method, returning an Action delegate that will be wrapped in an IDisposable.</param>        /// <returns>The observable sequence with the specified implementation for the Subscribe method.</returns>        /// <exception cref="ArgumentNullException"><paramref name="subscribeAsync"/> is null.</exception>        /// <remarks>This operator is especially useful in conjunction with the asynchronous programming features introduced in C# 5.0 and Visual Basic 11.</remarks>        public static IObservable<TResult> Create<TResult>(Func<IObserver<TResult>, Task<Action>> subscribeAsync)        {            if (subscribeAsync == null)                throw new ArgumentNullException("subscribeAsync");            return s_impl.Create<TResult>(subscribeAsync);        }#endif        #endregion        #region + Defer +        /// <summary>        /// Returns an observable sequence that invokes the specified factory function whenever a new observer subscribes.        /// </summary>        /// <typeparam name="TResult">The type of the elements in the sequence returned by the factory function, and in the resulting sequence.</typeparam>        /// <param name="observableFactory">Observable factory function to invoke for each observer that subscribes to the resulting sequence.</param>        /// <returns>An observable sequence whose observers trigger an invocation of the given observable factory function.</returns>        /// <exception cref="ArgumentNullException"><paramref name="observableFactory"/> is null.</exception>        public static IObservable<TResult> Defer<TResult>(Func<IObservable<TResult>> observableFactory)        {            if (observableFactory == null)                throw new ArgumentNullException("observableFactory");            return s_impl.Defer<TResult>(observableFactory);        }        #endregion        #region + DeferAsync +#if !NO_TPL        /// <summary>        /// Returns an observable sequence that starts the specified asynchronous factory function whenever a new observer subscribes.        /// </summary>        /// <typeparam name="TResult">The type of the elements in the sequence returned by the factory function, and in the resulting sequence.</typeparam>        /// <param name="observableFactoryAsync">Asynchronous factory function to start for each observer that subscribes to the resulting sequence.</param>        /// <returns>An observable sequence whose observers trigger the given asynchronous observable factory function to be started.</returns>        /// <exception cref="ArgumentNullException"><paramref name="observableFactoryAsync"/> is null.</exception>        /// <remarks>This operator is especially useful in conjunction with the asynchronous programming features introduced in C# 5.0 and Visual Basic 11.</remarks>        public static IObservable<TResult> Defer<TResult>(Func<Task<IObservable<TResult>>> observableFactoryAsync)        {            if (observableFactoryAsync == null)                throw new ArgumentNullException("observableFactoryAsync");            return s_impl.Defer<TResult>(observableFactoryAsync);        }        /// <summary>        /// Returns an observable sequence that starts the specified cancellable asynchronous factory function whenever a new observer subscribes.        /// The CancellationToken passed to the asynchronous factory function is tied to the returned disposable subscription, allowing best-effort cancellation.        /// </summary>        /// <typeparam name="TResult">The type of the elements in the sequence returned by the factory function, and in the resulting sequence.</typeparam>        /// <param name="observableFactoryAsync">Asynchronous factory function to start for each observer that subscribes to the resulting sequence.</param>        /// <returns>An observable sequence whose observers trigger the given asynchronous observable factory function to be started.</returns>        /// <exception cref="ArgumentNullException"><paramref name="observableFactoryAsync"/> is null.</exception>        /// <remarks>This operator is especially useful in conjunction with the asynchronous programming features introduced in C# 5.0 and Visual Basic 11.</remarks>        /// <remarks>When a subscription to the resulting sequence is disposed, the CancellationToken that was fed to the asynchronous observable factory function will be signaled.</remarks>        public static IObservable<TResult> DeferAsync<TResult>(Func<CancellationToken, Task<IObservable<TResult>>> observableFactoryAsync)        {            if (observableFactoryAsync == null)                throw new ArgumentNullException("observableFactoryAsync");            return s_impl.Defer<TResult>(observableFactoryAsync);        }#endif        #endregion        #region + Empty +        /// <summary>        /// Returns an empty observable sequence.        /// </summary>        /// <typeparam name="TResult">The type used for the IObservable<T> type parameter of the resulting sequence.</typeparam>        /// <returns>An observable sequence with no elements.</returns>        public static IObservable<TResult> Empty<TResult>()        {            return s_impl.Empty<TResult>();        }        /// <summary>        /// Returns an empty observable sequence.        /// </summary>        /// <typeparam name="TResult">The type used for the IObservable<T> type parameter of the resulting sequence.</typeparam>        /// <param name="witness">Object solely used to infer the type of the <typeparamref name="TResult"/> type parameter. This parameter is typically used when creating a sequence of anonymously typed elements.</param>        /// <returns>An observable sequence with no elements.</returns>        public static IObservable<TResult> Empty<TResult>(TResult witness)        {            return s_impl.Empty<TResult>(); // Pure inference - no specialized target method.        }        /// <summary>        /// Returns an empty observable sequence, using the specified scheduler to send out the single OnCompleted message.        /// </summary>        /// <typeparam name="TResult">The type used for the IObservable<T> type parameter of the resulting sequence.</typeparam>        /// <param name="scheduler">Scheduler to send the termination call on.</param>        /// <returns>An observable sequence with no elements.</returns>        /// <exception cref="ArgumentNullException"><paramref name="scheduler"/> is null.</exception>        public static IObservable<TResult> Empty<TResult>(IScheduler scheduler)        {            if (scheduler == null)                throw new ArgumentNullException("scheduler");            return s_impl.Empty<TResult>(scheduler);        }        /// <summary>        /// Returns an empty observable sequence, using the specified scheduler to send out the single OnCompleted message.        /// </summary>        /// <typeparam name="TResult">The type used for the IObservable<T> type parameter of the resulting sequence.</typeparam>        /// <param name="scheduler">Scheduler to send the termination call on.</param>        /// <param name="witness">Object solely used to infer the type of the <typeparamref name="TResult"/> type parameter. This parameter is typically used when creating a sequence of anonymously typed elements.</param>        /// <returns>An observable sequence with no elements.</returns>        /// <exception cref="ArgumentNullException"><paramref name="scheduler"/> is null.</exception>        public static IObservable<TResult> Empty<TResult>(IScheduler scheduler, TResult witness)        {            if (scheduler == null)                throw new ArgumentNullException("scheduler");            return s_impl.Empty<TResult>(scheduler); // Pure inference - no specialized target method.        }        #endregion        #region + Generate +        /// <summary>        /// Generates an observable sequence by running a state-driven loop producing the sequence's elements.        /// </summary>        /// <typeparam name="TState">The type of the state used in the generator loop.</typeparam>        /// <typeparam name="TResult">The type of the elements in the produced sequence.</typeparam>        /// <param name="initialState">Initial state.</param>        /// <param name="condition">Condition to terminate generation (upon returning false).</param>        /// <param name="iterate">Iteration step function.</param>        /// <param name="resultSelector">Selector function for results produced in the sequence.</param>        /// <returns>The generated sequence.</returns>        /// <exception cref="ArgumentNullException"><paramref name="condition"/> or <paramref name="iterate"/> or <paramref name="resultSelector"/> is null.</exception>        public static IObservable<TResult> Generate<TState, TResult>(TState initialState, Func<TState, bool> condition, Func<TState, TState> iterate, Func<TState, TResult> resultSelector)        {            if (condition == null)                throw new ArgumentNullException("condition");            if (iterate == null)                throw new ArgumentNullException("iterate");            if (resultSelector == null)                throw new ArgumentNullException("resultSelector");            return s_impl.Generate<TState, TResult>(initialState, condition, iterate, resultSelector);        }        /// <summary>        /// Generates an observable sequence by running a state-driven loop producing the sequence's elements, using the specified scheduler to send out observer messages.        /// </summary>        /// <typeparam name="TState">The type of the state used in the generator loop.</typeparam>        /// <typeparam name="TResult">The type of the elements in the produced sequence.</typeparam>        /// <param name="initialState">Initial state.</param>        /// <param name="condition">Condition to terminate generation (upon returning false).</param>        /// <param name="iterate">Iteration step function.</param>        /// <param name="resultSelector">Selector function for results produced in the sequence.</param>        /// <param name="scheduler">Scheduler on which to run the generator loop.</param>        /// <returns>The generated sequence.</returns>        /// <exception cref="ArgumentNullException"><paramref name="condition"/> or <paramref name="iterate"/> or <paramref name="resultSelector"/> or <paramref name="scheduler"/> is null.</exception>        public static IObservable<TResult> Generate<TState, TResult>(TState initialState, Func<TState, bool> condition, Func<TState, TState> iterate, Func<TState, TResult> resultSelector, IScheduler scheduler)        {            if (condition == null)                throw new ArgumentNullException("condition");            if (iterate == null)                throw new ArgumentNullException("iterate");            if (resultSelector == null)                throw new ArgumentNullException("resultSelector");            if (scheduler == null)                throw new ArgumentNullException("scheduler");            return s_impl.Generate<TState, TResult>(initialState, condition, iterate, resultSelector, scheduler);        }        #endregion        #region + Never +        /// <summary>        /// Returns a non-terminating observable sequence, which can be used to denote an infinite duration (e.g. when using reactive joins).        /// </summary>        /// <typeparam name="TResult">The type used for the IObservable<T> type parameter of the resulting sequence.</typeparam>        /// <returns>An observable sequence whose observers will never get called.</returns>        public static IObservable<TResult> Never<TResult>()        {            return s_impl.Never<TResult>();        }        /// <summary>        /// Returns a non-terminating observable sequence, which can be used to denote an infinite duration (e.g. when using reactive joins).        /// </summary>        /// <typeparam name="TResult">The type used for the IObservable<T> type parameter of the resulting sequence.</typeparam>        /// <param name="witness">Object solely used to infer the type of the <typeparamref name="TResult"/> type parameter. This parameter is typically used when creating a sequence of anonymously typed elements.</param>        /// <returns>An observable sequence whose observers will never get called.</returns>        public static IObservable<TResult> Never<TResult>(TResult witness)        {            return s_impl.Never<TResult>(); // Pure inference - no specialized target method.        }        #endregion        #region + Range +        /// <summary>        /// Generates an observable sequence of integral numbers within a specified range.        /// </summary>        /// <param name="start">The value of the first integer in the sequence.</param>        /// <param name="count">The number of sequential integers to generate.</param>        /// <returns>An observable sequence that contains a range of sequential integral numbers.</returns>        /// <exception cref="ArgumentOutOfRangeException"><paramref name="count"/> is less than zero. -or- <paramref name="start"/> + <paramref name="count"/> - 1 is larger than <see cref="M:System.Int32.MaxValue"/>.</exception>        public static IObservable<int> Range(int start, int count)        {            var max = ((long)start) + count - 1;            if (count < 0 || max > int.MaxValue)                throw new ArgumentOutOfRangeException("count");            return s_impl.Range(start, count);        }        /// <summary>        /// Generates an observable sequence of integral numbers within a specified range, using the specified scheduler to send out observer messages.        /// </summary>        /// <param name="start">The value of the first integer in the sequence.</param>        /// <param name="count">The number of sequential integers to generate.</param>        /// <param name="scheduler">Scheduler to run the generator loop on.</param>        /// <returns>An observable sequence that contains a range of sequential integral numbers.</returns>        /// <exception cref="ArgumentOutOfRangeException"><paramref name="count"/> is less than zero. -or- <paramref name="start"/> + <paramref name="count"/> - 1 is larger than <see cref="M:System.Int32.MaxValue"/>.</exception>        /// <exception cref="ArgumentNullException"><paramref name="scheduler"/> is null.</exception>        public static IObservable<int> Range(int start, int count, IScheduler scheduler)        {            var max = ((long)start) + count - 1;            if (count < 0 || max > int.MaxValue)                throw new ArgumentOutOfRangeException("count");            if (scheduler == null)                throw new ArgumentNullException("scheduler");            return s_impl.Range(start, count, scheduler);        }        #endregion        #region + Repeat +        /// <summary>        /// Generates an observable sequence that repeats the given element infinitely.        /// </summary>        /// <typeparam name="TResult">The type of the element that will be repeated in the produced sequence.</typeparam>        /// <param name="value">Element to repeat.</param>        /// <returns>An observable sequence that repeats the given element infinitely.</returns>        public static IObservable<TResult> Repeat<TResult>(TResult value)        {            return s_impl.Repeat<TResult>(value);        }        /// <summary>        /// Generates an observable sequence that repeats the given element infinitely, using the specified scheduler to send out observer messages.        /// </summary>        /// <typeparam name="TResult">The type of the element that will be repeated in the produced sequence.</typeparam>        /// <param name="value">Element to repeat.</param>        /// <param name="scheduler">Scheduler to run the producer loop on.</param>        /// <returns>An observable sequence that repeats the given element infinitely.</returns>        /// <exception cref="ArgumentNullException"><paramref name="scheduler"/> is null.</exception>        public static IObservable<TResult> Repeat<TResult>(TResult value, IScheduler scheduler)        {            if (scheduler == null)                throw new ArgumentNullException("scheduler");            return s_impl.Repeat<TResult>(value, scheduler);        }        /// <summary>        /// Generates an observable sequence that repeats the given element the specified number of times.        /// </summary>        /// <typeparam name="TResult">The type of the element that will be repeated in the produced sequence.</typeparam>        /// <param name="value">Element to repeat.</param>        /// <param name="repeatCount">Number of times to repeat the element.</param>        /// <returns>An observable sequence that repeats the given element the specified number of times.</returns>        /// <exception cref="ArgumentOutOfRangeException"><paramref name="repeatCount"/> is less than zero.</exception>        public static IObservable<TResult> Repeat<TResult>(TResult value, int repeatCount)        {            if (repeatCount < 0)                throw new ArgumentOutOfRangeException("repeatCount");            return s_impl.Repeat<TResult>(value, repeatCount);        }        /// <summary>        /// Generates an observable sequence that repeats the given element the specified number of times, using the specified scheduler to send out observer messages.        /// </summary>        /// <typeparam name="TResult">The type of the element that will be repeated in the produced sequence.</typeparam>        /// <param name="value">Element to repeat.</param>        /// <param name="repeatCount">Number of times to repeat the element.</param>        /// <param name="scheduler">Scheduler to run the producer loop on.</param>        /// <returns>An observable sequence that repeats the given element the specified number of times.</returns>        /// <exception cref="ArgumentOutOfRangeException"><paramref name="repeatCount"/> is less than zero.</exception>        /// <exception cref="ArgumentNullException"><paramref name="scheduler"/> is null.</exception>        public static IObservable<TResult> Repeat<TResult>(TResult value, int repeatCount, IScheduler scheduler)        {            if (repeatCount < 0)                throw new ArgumentOutOfRangeException("repeatCount");            if (scheduler == null)                throw new ArgumentNullException("scheduler");            return s_impl.Repeat<TResult>(value, repeatCount, scheduler);        }        #endregion        #region + Return +        /// <summary>        /// Returns an observable sequence that contains a single element.        /// </summary>        /// <typeparam name="TResult">The type of the element that will be returned in the produced sequence.</typeparam>        /// <param name="value">Single element in the resulting observable sequence.</param>        /// <returns>An observable sequence containing the single specified element.</returns>        public static IObservable<TResult> Return<TResult>(TResult value)        {            return s_impl.Return<TResult>(value);        }        /// <summary>        /// Returns an observable sequence that contains a single element, using the specified scheduler to send out observer messages.        /// </summary>        /// <typeparam name="TResult">The type of the element that will be returned in the produced sequence.</typeparam>        /// <param name="value">Single element in the resulting observable sequence.</param>        /// <param name="scheduler">Scheduler to send the single element on.</param>        /// <returns>An observable sequence containing the single specified element.</returns>        /// <exception cref="ArgumentNullException"><paramref name="scheduler"/> is null.</exception>        public static IObservable<TResult> Return<TResult>(TResult value, IScheduler scheduler)        {            if (scheduler == null)                throw new ArgumentNullException("scheduler");            return s_impl.Return<TResult>(value, scheduler);        }        #endregion        #region + Throw +        /// <summary>        /// Returns an observable sequence that terminates with an exception.        /// </summary>        /// <typeparam name="TResult">The type used for the IObservable<T> type parameter of the resulting sequence.</typeparam>        /// <param name="exception">Exception object used for the sequence's termination.</param>        /// <returns>The observable sequence that terminates exceptionally with the specified exception object.</returns>        /// <exception cref="ArgumentNullException"><paramref name="exception"/> is null.</exception>        public static IObservable<TResult> Throw<TResult>(Exception exception)        {            if (exception == null)                throw new ArgumentNullException("exception");            return s_impl.Throw<TResult>(exception);        }        /// <summary>        /// Returns an observable sequence that terminates with an exception.        /// </summary>        /// <typeparam name="TResult">The type used for the IObservable<T> type parameter of the resulting sequence.</typeparam>        /// <param name="exception">Exception object used for the sequence's termination.</param>        /// <param name="witness">Object solely used to infer the type of the <typeparamref name="TResult"/> type parameter. This parameter is typically used when creating a sequence of anonymously typed elements.</param>        /// <returns>The observable sequence that terminates exceptionally with the specified exception object.</returns>        /// <exception cref="ArgumentNullException"><paramref name="exception"/> is null.</exception>        public static IObservable<TResult> Throw<TResult>(Exception exception, TResult witness)        {            if (exception == null)                throw new ArgumentNullException("exception");            return s_impl.Throw<TResult>(exception); // Pure inference - no specialized target method.        }        /// <summary>        /// Returns an observable sequence that terminates with an exception, using the specified scheduler to send out the single OnError message.        /// </summary>        /// <typeparam name="TResult">The type used for the IObservable<T> type parameter of the resulting sequence.</typeparam>        /// <param name="exception">Exception object used for the sequence's termination.</param>        /// <param name="scheduler">Scheduler to send the exceptional termination call on.</param>        /// <returns>The observable sequence that terminates exceptionally with the specified exception object.</returns>        /// <exception cref="ArgumentNullException"><paramref name="exception"/> or <paramref name="scheduler"/> is null.</exception>        public static IObservable<TResult> Throw<TResult>(Exception exception, IScheduler scheduler)        {            if (exception == null)                throw new ArgumentNullException("exception");            if (scheduler == null)                throw new ArgumentNullException("scheduler");            return s_impl.Throw<TResult>(exception, scheduler);        }        /// <summary>        /// Returns an observable sequence that terminates with an exception, using the specified scheduler to send out the single OnError message.        /// </summary>        /// <typeparam name="TResult">The type used for the IObservable<T> type parameter of the resulting sequence.</typeparam>        /// <param name="exception">Exception object used for the sequence's termination.</param>        /// <param name="scheduler">Scheduler to send the exceptional termination call on.</param>        /// <param name="witness">Object solely used to infer the type of the <typeparamref name="TResult"/> type parameter. This parameter is typically used when creating a sequence of anonymously typed elements.</param>        /// <returns>The observable sequence that terminates exceptionally with the specified exception object.</returns>        /// <exception cref="ArgumentNullException"><paramref name="exception"/> or <paramref name="scheduler"/> is null.</exception>        public static IObservable<TResult> Throw<TResult>(Exception exception, IScheduler scheduler, TResult witness)        {            if (exception == null)                throw new ArgumentNullException("exception");            if (scheduler == null)                throw new ArgumentNullException("scheduler");            return s_impl.Throw<TResult>(exception, scheduler); // Pure inference - no specialized target method.        }        #endregion        #region + Using +        /// <summary>        /// Constructs an observable sequence that depends on a resource object, whose lifetime is tied to the resulting observable sequence's lifetime.        /// </summary>        /// <typeparam name="TResult">The type of the elements in the produced sequence.</typeparam>        /// <typeparam name="TResource">The type of the resource used during the generation of the resulting sequence. Needs to implement <see cref="System.IDisposable"/>.</typeparam>        /// <param name="resourceFactory">Factory function to obtain a resource object.</param>        /// <param name="observableFactory">Factory function to obtain an observable sequence that depends on the obtained resource.</param>        /// <returns>An observable sequence whose lifetime controls the lifetime of the dependent resource object.</returns>        /// <exception cref="ArgumentNullException"><paramref name="resourceFactory"/> or <paramref name="observableFactory"/> is null.</exception>        public static IObservable<TResult> Using<TResult, TResource>(Func<TResource> resourceFactory, Func<TResource, IObservable<TResult>> observableFactory) where TResource : IDisposable        {            if (resourceFactory == null)                throw new ArgumentNullException("resourceFactory");            if (observableFactory == null)                throw new ArgumentNullException("observableFactory");            return s_impl.Using<TResult, TResource>(resourceFactory, observableFactory);        }        #endregion        #region + UsingAsync +#if !NO_TPL        /// <summary>        /// Constructs an observable sequence that depends on a resource object, whose lifetime is tied to the resulting observable sequence's lifetime. The resource is obtained and used through asynchronous methods.        /// The CancellationToken passed to the asynchronous methods is tied to the returned disposable subscription, allowing best-effort cancellation at any stage of the resource acquisition or usage.        /// </summary>        /// <typeparam name="TResult">The type of the elements in the produced sequence.</typeparam>        /// <typeparam name="TResource">The type of the resource used during the generation of the resulting sequence. Needs to implement <see cref="System.IDisposable"/>.</typeparam>        /// <param name="resourceFactoryAsync">Asynchronous factory function to obtain a resource object.</param>        /// <param name="observableFactoryAsync">Asynchronous factory function to obtain an observable sequence that depends on the obtained resource.</param>        /// <returns>An observable sequence whose lifetime controls the lifetime of the dependent resource object.</returns>        /// <exception cref="ArgumentNullException"><paramref name="resourceFactoryAsync"/> or <paramref name="observableFactoryAsync"/> is null.</exception>        /// <remarks>This operator is especially useful in conjunction with the asynchronous programming features introduced in C# 5.0 and Visual Basic 11.</remarks>        /// <remarks>When a subscription to the resulting sequence is disposed, the CancellationToken that was fed to the asynchronous resource factory and observable factory functions will be signaled.</remarks>        public static IObservable<TResult> Using<TResult, TResource>(Func<CancellationToken, Task<TResource>> resourceFactoryAsync, Func<TResource, CancellationToken, Task<IObservable<TResult>>> observableFactoryAsync) where TResource : IDisposable        {            if (resourceFactoryAsync == null)                throw new ArgumentNullException("resourceFactoryAsync");            if (observableFactoryAsync == null)                throw new ArgumentNullException("observableFactoryAsync");            return s_impl.Using<TResult, TResource>(resourceFactoryAsync, observableFactoryAsync);        }#endif        #endregion    }}
 |