1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980 |
- // 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.Reactive.Concurrency;
- using System.Reactive.Disposables;
- namespace System.Reactive.Linq
- {
- public partial class AsyncObservable
- {
- public static IAsyncObservable<TSource> DelaySubscription<TSource>(this IAsyncObservable<TSource> source, TimeSpan dueTime)
- {
- if (source == null)
- throw new ArgumentNullException(nameof(source));
- return DelaySubscription(source, dueTime, TaskPoolAsyncScheduler.Default);
- }
- public static IAsyncObservable<TSource> DelaySubscription<TSource>(this IAsyncObservable<TSource> source, TimeSpan dueTime, IAsyncScheduler scheduler)
- {
- if (source == null)
- throw new ArgumentNullException(nameof(source));
- if (scheduler == null)
- throw new ArgumentNullException(nameof(scheduler));
- return Create(
- source,
- (dueTime, scheduler),
- static async (source, state, observer) =>
- {
- var d = new CompositeAsyncDisposable();
- var task = await state.scheduler.ScheduleAsync(async ct =>
- {
- var inner = await source.SubscribeSafeAsync(observer).ConfigureAwait(false);
- await d.AddAsync(inner).ConfigureAwait(false);
- }, state.dueTime).ConfigureAwait(false);
- await d.AddAsync(task).ConfigureAwait(false);
- return d;
- });
- }
- public static IAsyncObservable<TSource> DelaySubscription<TSource>(this IAsyncObservable<TSource> source, DateTimeOffset dueTime)
- {
- if (source == null)
- throw new ArgumentNullException(nameof(source));
- return DelaySubscription(source, dueTime, TaskPoolAsyncScheduler.Default);
- }
- public static IAsyncObservable<TSource> DelaySubscription<TSource>(this IAsyncObservable<TSource> source, DateTimeOffset dueTime, IAsyncScheduler scheduler)
- {
- if (source == null)
- throw new ArgumentNullException(nameof(source));
- if (scheduler == null)
- throw new ArgumentNullException(nameof(scheduler));
- return Create(
- source,
- (dueTime, scheduler),
- static async (source, state, observer) =>
- {
- var d = new CompositeAsyncDisposable();
- var task = await state.scheduler.ScheduleAsync(async ct =>
- {
- var inner = await source.SubscribeSafeAsync(observer).ConfigureAwait(false);
- await d.AddAsync(inner).ConfigureAwait(false);
- }, state.dueTime).ConfigureAwait(false);
- await d.AddAsync(task).ConfigureAwait(false);
- return d;
- });
- }
- }
- }
|