import { IterableX } from '../iterablex.js'; import { MonoTypeOperatorFunction } from '../../interfaces.js'; /** @ignore */ export class ExpandIterable extends IterableX { private _source: Iterable; private _fn: (value: TSource) => Iterable; constructor(source: Iterable, fn: (value: TSource) => Iterable) { super(); this._source = source; this._fn = fn; } *[Symbol.iterator]() { const q = [this._source]; while (q.length > 0) { const src = q.shift(); for (const item of src!) { q.push(this._fn(item)); yield item; } } } } /** * Expands (breadth first) the iterable sequence by recursively applying a selector function to generate more sequences at each recursion level. * * @template TSource Source sequence element type. * @param {(( value: TSource) => Iterable)} selector Selector function to retrieve the next sequence to expand. * @returns {MonoTypeOperatorFunction} An operator which returns a sequence with results * from the recursive expansion of the source sequence. */ export function expand( selector: (value: TSource) => Iterable ): MonoTypeOperatorFunction { return function expandOperatorFunction(source: Iterable): IterableX { return new ExpandIterable(source, selector); }; }