// 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.Reactive.Subjects;
using System.Threading;
namespace System.Reactive.Linq
{
public static partial class Observable
{
///
/// Gets an awaiter that returns the last value of the observable sequence or throws an exception if the sequence is empty.
/// This operation subscribes to the observable sequence, making it hot.
///
/// The type of the elements in the source sequence.
/// Source sequence to await.
/// Object that can be awaited.
/// is null.
public static AsyncSubject GetAwaiter(this IObservable source)
{
if (source == null)
{
throw new ArgumentNullException(nameof(source));
}
return s_impl.GetAwaiter(source);
}
///
/// Gets an awaiter that returns the last value of the observable sequence or throws an exception if the sequence is empty.
/// This operation subscribes and connects to the observable sequence, making it hot.
///
/// The type of the elements in the source sequence.
/// Source sequence to await.
/// Object that can be awaited.
/// is null.
public static AsyncSubject GetAwaiter(this IConnectableObservable source)
{
if (source == null)
{
throw new ArgumentNullException(nameof(source));
}
return s_impl.GetAwaiter(source);
}
///
/// Gets an awaiter that returns the last value of the observable sequence or throws an exception if the sequence is empty.
/// This operation subscribes to the observable sequence, making it hot. The supplied CancellationToken can be used to cancel the subscription.
///
/// The type of the elements in the source sequence.
/// Source sequence to await.
/// Cancellation token.
/// Object that can be awaited.
/// is null.
public static AsyncSubject RunAsync(this IObservable source, CancellationToken cancellationToken)
{
if (source == null)
{
throw new ArgumentNullException(nameof(source));
}
return s_impl.RunAsync(source, cancellationToken);
}
///
/// Gets an awaiter that returns the last value of the observable sequence or throws an exception if the sequence is empty.
/// This operation subscribes and connects to the observable sequence, making it hot. The supplied CancellationToken can be used to cancel the subscription and connection.
///
/// The type of the elements in the source sequence.
/// Source sequence to await.
/// Cancellation token.
/// Object that can be awaited.
/// is null.
public static AsyncSubject RunAsync(this IConnectableObservable source, CancellationToken cancellationToken)
{
if (source == null)
{
throw new ArgumentNullException(nameof(source));
}
return s_impl.RunAsync(source, cancellationToken);
}
}
}