Transform stream supporting objectMode, which batches a bunch of input data into groups of specified size and will emit arrays, so that you can deal with pieces of input asynchronously.
npm install --save batched-stream
const BatchStream = require('batched-stream')
const batch = new BatchStream({
size : 5, // Bytes or N. of objects (when objectMode is true)
objectMode: true, // false by default
strictMode: false // return the rest of the batch when a stream contains a number of items that is not a strict multiply of the batch size
})
stream
.pipe(batch)
.pipe(new ArrayStream()) // In objectMode: true, deals with array input from pipe.
You can .pipe
other streams to it or .write
them yourself (if you .write
don't forget to .end
). The options are passed down to the transform stream (you can increase the highWaterMark
for example).
-
If
objectMode
is enabled the emitted batches areArray
of length equal tosize
. OtherwiseBuffer
with bytesize
-length are emitted. -
The
strictMode: false
allows to get the rest of the batch when a stream contains a number of items that is not a strict multiply of the batch size.
npm test
Rocco Musolino (@roccomuso)
MIT