@tanstack/db-ivm
Version:
Incremental View Maintenance for TanStack DB based on Differential Dataflow
34 lines (33 loc) • 821 B
JavaScript
;
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
const graph = require("../graph.cjs");
const d2 = require("../d2.cjs");
class MapOperator extends graph.LinearUnaryOperator {
#f;
constructor(id, inputA, output, f) {
super(id, inputA, output);
this.#f = f;
}
inner(collection) {
return collection.map(this.#f);
}
}
function map(f) {
return (stream) => {
const output = new d2.StreamBuilder(
stream.graph,
new graph.DifferenceStreamWriter()
);
const operator = new MapOperator(
stream.graph.getNextOperatorId(),
stream.connectReader(),
output.writer,
f
);
stream.graph.addOperator(operator);
return output;
};
}
exports.MapOperator = MapOperator;
exports.map = map;
//# sourceMappingURL=map.cjs.map