UNPKG

mingo

Version:

MongoDB query language for in-memory objects

100 lines (99 loc) 3.14 kB
import { Any, Callback, Predicate } from "./types"; /** * A value produced by a generator */ export interface IteratorResult<T = Any> { readonly value?: T; readonly done: boolean; } /** * Simplified generator interface */ interface Generator<T> { next: () => T; } export type Source = Generator<IteratorResult> | Callback<IteratorResult> | Any[]; /** * Returns an iterator * @param {*} source An iterable source (Array, Function, Generator, or Iterator) */ export declare function Lazy(source: Source): Iterator; /** * Concatenate multiple iterators and return a new iterator. * * @param iterators The iterators to concatenate * @returns {Iterator} A new iterator */ export declare function concat(...iterators: Iterator[]): Iterator; /** * A lazy collection iterator yields a single value at a time upon request. */ export declare class Iterator { #private; private isDone; /** * @param {*} source An iterable object or function. * Array - return one element per cycle * Object{next:Function} - call next() for the next value (this also handles generator functions) * Function - call to return the next value * @param {Function} fn An optional transformation function */ constructor(source: Source); /** * Add an iteratee to this lazy sequence */ private push; next<T = Any>(): IteratorResult<T>; /** * Transform each item in the sequence to a new value * @param {Function} f */ map<T = Any>(f: Callback<T>): Iterator; /** * Select only items matching the given predicate * @param {Function} pred */ filter<T = Any>(predicate: Predicate<T>): Iterator; /** * Take given numbe for values from sequence * @param {Number} n A number greater than 0 */ take(n: number): Iterator; /** * Drop a number of values from the sequence * @param {Number} n Number of items to drop greater than 0 */ drop(n: number): Iterator; /** * Returns a new lazy object with results of the transformation * The entire sequence is realized. * * @param {Callback<Source, Any[]>} fn Tranform function of type (Array) => (Any) */ transform(fn: Callback<Source, Any[]>): Iterator; /** * Returns the fully realized values of the iterators. * The return value will be an array unless `lazy.first()` was used. * The realized values are cached for subsequent calls. */ value<T>(): T[]; /** * Execute the funcion for each value. Will stop when an execution returns false. * @param {Function} f * @returns {Boolean} false iff `f` return false for AnyVal execution, otherwise true */ each<T = Any>(f: Callback<T>): boolean; /** * Returns the reduction of sequence according the reducing function * * @param {*} f a reducing function * @param {*} initialValue */ reduce<T = Any>(f: Callback<T>, initialValue?: Any): T; /** * Returns the number of matched items in the sequence */ size(): number; [Symbol.iterator](): Iterator; } export {};