ix
Version:
The Interactive Extensions for JavaScript
47 lines (41 loc) • 1.47 kB
text/typescript
import { AsyncIterableX } from '../asynciterablex.js';
import { OperatorAsyncFunction } from '../../interfaces.js';
import { wrapWithAbort } from './withabort.js';
import { throwIfAborted } from '../../aborterror.js';
/** @ignore */
export interface TimeInterval<T> {
value: T;
elapsed: number;
}
/** @ignore */
export class TimeIntervalAsyncIterable<TSource> extends AsyncIterableX<TimeInterval<TSource>> {
private _source: AsyncIterable<TSource>;
constructor(source: AsyncIterable<TSource>) {
super();
this._source = source;
}
async *[Symbol.asyncIterator](signal?: AbortSignal) {
throwIfAborted(signal);
let last = Date.now();
for await (const item of wrapWithAbort(this._source, signal)) {
const now = Date.now();
const span = now - last;
last = now;
yield { value: item, elapsed: span };
}
}
}
/**
* Records the time interval between consecutive elements in an async-iterable sequence.
*
* @template TSource The type of the elements in the source sequence.
* @returns {OperatorAsyncFunction<TSource, TimeInterval<TSource>>} An async-iterable sequence with time
* interval information on elements.
*/
export function timeInterval<TSource>(): OperatorAsyncFunction<TSource, TimeInterval<TSource>> {
return function timeIntervalOperatorFunction(
source: AsyncIterable<TSource>
): AsyncIterableX<TimeInterval<TSource>> {
return new TimeIntervalAsyncIterable<TSource>(source);
};
}