From cde9fc6a8fe569203cb991121a35c2a9c7f4c420 Mon Sep 17 00:00:00 2001 From: Atsushi Eno Date: Tue, 22 Jan 2013 17:25:22 +0900 Subject: import 2b5dbddd740b, new directory structure in the original rx. --- .../Reactive/Linq/Observable/TimeInterval.cs | 73 ++++++++++++++++++++++ 1 file changed, 73 insertions(+) create mode 100644 Rx/NET/Source/System.Reactive.Linq/Reactive/Linq/Observable/TimeInterval.cs (limited to 'Rx/NET/Source/System.Reactive.Linq/Reactive/Linq/Observable/TimeInterval.cs') diff --git a/Rx/NET/Source/System.Reactive.Linq/Reactive/Linq/Observable/TimeInterval.cs b/Rx/NET/Source/System.Reactive.Linq/Reactive/Linq/Observable/TimeInterval.cs new file mode 100644 index 0000000..dacfa03 --- /dev/null +++ b/Rx/NET/Source/System.Reactive.Linq/Reactive/Linq/Observable/TimeInterval.cs @@ -0,0 +1,73 @@ +// Copyright (c) Microsoft Open Technologies, Inc. All rights reserved. See License.txt in the project root for license information. + +#if !NO_PERF +using System; +using System.Diagnostics; +using System.Reactive.Concurrency; +using System.Reactive.Disposables; +using System.Threading; + +namespace System.Reactive.Linq.Observαble +{ + class TimeInterval : Producer> + { + private readonly IObservable _source; + private readonly IScheduler _scheduler; + + public TimeInterval(IObservable source, IScheduler scheduler) + { + _source = source; + _scheduler = scheduler; + } + + protected override IDisposable Run(IObserver> observer, IDisposable cancel, Action setSink) + { + var sink = new _(this, observer, cancel); + setSink(sink); + return sink.Run(); + } + + class _ : Sink>, IObserver + { + private readonly TimeInterval _parent; + + public _(TimeInterval parent, IObserver> observer, IDisposable cancel) + : base(observer, cancel) + { + _parent = parent; + } + + private IStopwatch _watch; + private TimeSpan _last; + + public IDisposable Run() + { + _watch = _parent._scheduler.StartStopwatch(); + _last = TimeSpan.Zero; + + return _parent._source.Subscribe(this); + } + + public void OnNext(TSource value) + { + var now = _watch.Elapsed; + var span = now.Subtract(_last); + _last = now; + base._observer.OnNext(new System.Reactive.TimeInterval(value, span)); + } + + public void OnError(Exception error) + { + base._observer.OnError(error); + Dispose(); + } + + public void OnCompleted() + { + base._observer.OnCompleted(); + Dispose(); + } + } + } +} +#endif \ No newline at end of file -- cgit v1.2.3