spica
Version:
Supervisor, Coroutine, Channel, select, AtomicPromise, Cancellation, Cache, List, Queue, Stack, and some utils.
14 lines (12 loc) • 645 B
text/typescript
import { Sequence } from '../../core';
import { compose } from '../../../../helper/compose';
compose(Sequence, class <a, z> extends Sequence<a, z> {
public override reduce(): Sequence<a, [number, Map<number, Sequence.Thunk<a>>]> {
return new Sequence<a, [number, Map<number, Sequence.Thunk<a>>]>(
([i, memo] = [0, new Map<number, Sequence.Thunk<a>>()], cons) =>
Sequence.Iterator.when(
memo.get(i) || memo.set(i, i > 0 && memo.has(i - 1) ? Sequence.Thunk.iterator(memo.get(i - 1)!)() : this.iterate()).get(i)!,
() => cons(),
thunk => cons(Sequence.Thunk.value(thunk), [i + 1, memo])));
}
});