writable-stream-parallel
v0.1.0
Published
Parallelize your _write()s and _transform()s
Downloads
43
Readme
writable-stream-parallel
Extension of the new node.js Writable stream interface that allows for parallel writes.
Installation
npm install writable-stream-parallel
Currently only tested on node v0.9.12.
Motivation
The normal node Writable stream can only perform one write at a time. For example:
var Readable = require('stream').Readable;
var Writable = require('stream').Writable
var r = new Readable({ objectMode: true });
r._read = function noop() {}
r.push(1);
r.push(2);
r.push(3);
var writable = new Writable({objectMode: true});
writable._write = function(chunk, encoding, cb) {
console.log('writing', chunk);
setTimeout(function() { console.log('wrote', chunk); cb(); }, 100);
};
r.pipe(writable);
Output:
writing 1
wrote 1
writing 2
wrote 2
writing 3
wrote 3
stream-writable-parallel behavior
Serial writes limit the usefulness of streams in a lot of settings. stream-writable-parallel
provides a Writable class that parallelizes calls to _write
up to a certain maxWrites
:
var Writable = require('stream-writable-parallel').Writable;
var writable = new Writable({objectMode: true, maxWrites: 10});
writable._write = function(chunk, encoding, cb) {
console.log('writing', chunk);
setTimeout(function() { console.log('wrote', chunk); cb(); }, 100);
};
r.pipe(writable);
Output:
writing 1
writing 2
writing 3
wrote 1
wrote 2
wrote 3