import { AsyncIterableX } from '../asynciterablex.js'; import { MonoTypeOperatorAsyncFunction } from '../../interfaces.js'; import { wrapWithAbort } from './withabort.js'; import { throwIfAborted } from '../../aborterror.js'; /** @ignore */ export class TakeAsyncIterable extends AsyncIterableX { private _source: AsyncIterable; private _count: number; constructor(source: AsyncIterable, count: number) { super(); this._source = source; this._count = count; } async *[Symbol.asyncIterator](signal?: AbortSignal) { throwIfAborted(signal); let i = this._count; if (i > 0) { for await (const item of wrapWithAbort(this._source, signal)) { yield item; if (--i === 0) { break; } } } } } /** * Returns a specified number of contiguous elements from the start of an async-iterable sequence. * * @template TSource The type of the elements in the source sequence. * @param {number} count The number of elements to return. * @returns {MonoTypeOperatorAsyncFunction} An async-iterable sequence that contains the specified * number of elements from the start of the input sequence. */ export function take(count: number): MonoTypeOperatorAsyncFunction { return function takeOperatorFunction(source: AsyncIterable): AsyncIterableX { return new TakeAsyncIterable(source, count); }; }