@electric-sql/d2mini
Version:
D2Mini is a minimal implementation of Differential Dataflow for performing in-memory incremental view maintenance.
14 lines (13 loc) • 704 B
TypeScript
import { IStreamBuilder, KeyValue } from '../types.js';
import { DifferenceStreamReader, DifferenceStreamWriter } from '../graph.js';
import { ReduceOperator } from './reduce.js';
/**
* Operator that removes duplicates by key (version-free)
*/
export declare class DistinctOperator<K, V> extends ReduceOperator<K, V, V> {
constructor(id: number, inputA: DifferenceStreamReader<[K, V]>, output: DifferenceStreamWriter<[K, V]>);
}
/**
* Removes duplicates by key (version-free)
*/
export declare function distinct<K extends T extends KeyValue<infer K, infer _V> ? K : never, V extends T extends KeyValue<K, infer V> ? V : never, T>(): (stream: IStreamBuilder<T>) => IStreamBuilder<KeyValue<K, V>>;