flow-reduce
Version:
Through stream which performs a data reduction.
68 lines (44 loc) • 1.23 kB
Markdown
flow-reduce
==========
Through stream which performs a reduction.
var eventStream = require( 'event-stream' ),
rStream = require( 'flow-reduce' );
// Create some data...
var data = new Array( 1000 );
for ( var i = 0; i < 1000; i++ ) {
data[ i ] = Math.random();
}
// Create a readable stream:
var readStream = eventStream.readArray( data );
// Create a new reduce stream (counter):
var stream = rStream()
.reduce( function( acc, d ){
return acc+1;
})
.acc( 0 )
.stream();
// Pipe the data:
readStream.pipe( stream )
.pipe( eventStream.map( function( d, clbk ) {
clbk( null, d.toString() );
}))
.pipe( process.stdout );
```
Unit tests use the [Mocha](http://visionmedia.github.io/mocha) test framework with [Chai](http://chaijs.com) assertions.
Assuming you have installed Mocha, execute the following command in the top-level application directory to run the tests:
``` bash
$ mocha
```
All new feature development should have corresponding unit tests to validate correct functionality.
[ ](http://opensource.org/licenses/MIT).
---
Copyright © 2014. Athan Reines.
``` bash
$ npm install flow-reduce
```
``` javascript