121 lines
3.9 KiB
Markdown
121 lines
3.9 KiB
Markdown
|
# StreamQueue
|
|||
|
> StreamQueue pipe the queued streams one by one in order to preserve their content
|
|||
|
order.
|
|||
|
|
|||
|
[data:image/s3,"s3://crabby-images/bc230/bc2302f49d0feff1c39ab5f3ad2c4c41628f4eeb" alt="NPM version"](https://npmjs.org/package/streamqueue) [data:image/s3,"s3://crabby-images/4d1e5/4d1e5d33e3cbf840e9d2906b80a346ad8cc84555" alt="Build Status"](https://travis-ci.org/nfroidure/StreamQueue) [data:image/s3,"s3://crabby-images/89f66/89f66b54e4efb802f42a10862f6bc79f4717ab17" alt="Dependency Status"](https://david-dm.org/nfroidure/streamqueue) [data:image/s3,"s3://crabby-images/3e25f/3e25f7258ea2efe000a96031d8a3756b0d127bba" alt="devDependency Status"](https://david-dm.org/nfroidure/streamqueue#info=devDependencies) [data:image/s3,"s3://crabby-images/4114d/4114d5da499e60b5d2339d421ede9138b8dba526" alt="Coverage Status"](https://coveralls.io/r/nfroidure/StreamQueue?branch=master) [data:image/s3,"s3://crabby-images/e7bae/e7bae46d23656841e15bbeb9eb0da334dac9c826" alt="Code Climate"](https://codeclimate.com/github/nfroidure/StreamQueue)
|
|||
|
|
|||
|
## Usage
|
|||
|
Install the [npm module](https://npmjs.org/package/streamqueue):
|
|||
|
```sh
|
|||
|
npm install streamqueue --save
|
|||
|
```
|
|||
|
Then, in your scripts:
|
|||
|
```js
|
|||
|
var streamqueue = require('streamqueue');
|
|||
|
|
|||
|
var queue = streamqueue(
|
|||
|
Fs.createReadStream('input.txt'),
|
|||
|
Fs.createReadStream('input2.txt'),
|
|||
|
Fs.createReadStream('input3.txt')
|
|||
|
).pipe(process.stdout);
|
|||
|
```
|
|||
|
StreamQueue also accept functions returning streams, the above can be written
|
|||
|
like this, doing system calls only when piping:
|
|||
|
```js
|
|||
|
var streamqueue = require('streamqueue');
|
|||
|
|
|||
|
var queue = streamqueue(
|
|||
|
Fs.createReadStream.bind(null, 'input.txt'),
|
|||
|
Fs.createReadStream.bind(null, 'input2.txt'),
|
|||
|
Fs.createReadStream.bind(null, 'input3.txt')
|
|||
|
).pipe(process.stdout);
|
|||
|
```
|
|||
|
|
|||
|
Object-oriented traditionnal API offers more flexibility:
|
|||
|
```js
|
|||
|
var StreamQueue = require('streamqueue');
|
|||
|
|
|||
|
var queue = new StreamQueue();
|
|||
|
queue.queue(
|
|||
|
Fs.createReadStream('input.txt'),
|
|||
|
Fs.createReadStream('input2.txt'),
|
|||
|
Fs.createReadStream('input3.txt')
|
|||
|
);
|
|||
|
queue.done();
|
|||
|
|
|||
|
queue.pipe(process.stdout);
|
|||
|
```
|
|||
|
You can also chain StreamQueue methods like that:
|
|||
|
```js
|
|||
|
var StreamQueue = require('streamqueue');
|
|||
|
|
|||
|
new StreamQueue()
|
|||
|
.queue(Fs.createReadStream('input.txt'))
|
|||
|
.queue(Fs.createReadStream('input2.txt'))
|
|||
|
.queue(Fs.createReadStream('input3.txt'))
|
|||
|
.done()
|
|||
|
.pipe(process.stdout);
|
|||
|
```
|
|||
|
|
|||
|
You can queue new streams at any moment until you call the done() method. So the
|
|||
|
created stream will not fire the end event until done() call.
|
|||
|
|
|||
|
Note that stream queue is compatible with the Node 0.10+ streams. For older
|
|||
|
streams, stream queue will wrap them with
|
|||
|
[`Readable.wrap`](http://nodejs.org/api/stream.html#stream_readable_wrap_stream)
|
|||
|
before queueing. Please fix your dependencies or report issues to libraries
|
|||
|
using 0.8 streams since this extra code will finally be removed.
|
|||
|
|
|||
|
## API
|
|||
|
|
|||
|
### StreamQueue([options], [stream1, stream2, ... streamN])
|
|||
|
|
|||
|
#### options
|
|||
|
|
|||
|
##### options.objectMode
|
|||
|
Type: `Boolean`
|
|||
|
Default value: `false`
|
|||
|
|
|||
|
Use if piped in streams are in object mode. In this case, the stream queue will
|
|||
|
also be in the object mode.
|
|||
|
|
|||
|
##### options.pauseFlowingStream
|
|||
|
Type: `Boolean`
|
|||
|
Default value: `true`
|
|||
|
|
|||
|
If a stream is in flowing mode, then it will be paused before queueing.
|
|||
|
|
|||
|
##### options.resumeFlowingStream
|
|||
|
Type: `Boolean`
|
|||
|
Default value: `true`
|
|||
|
|
|||
|
If a stream is in flowing mode, then it will be resumed before piping.
|
|||
|
|
|||
|
##### options.*
|
|||
|
|
|||
|
StreamQueue inherits of Stream.PassThrough, the options are passed to the
|
|||
|
parent constructor so you can use it's options too.
|
|||
|
|
|||
|
#### streamN
|
|||
|
Type: `Stream`
|
|||
|
|
|||
|
Append streams given in argument to the queue and ends when the queue is empty.
|
|||
|
|
|||
|
### StreamQueue.queue(stream1, [stream2, ... streamN])
|
|||
|
|
|||
|
Append streams given in argument to the queue.
|
|||
|
|
|||
|
### StreamQueue.done([stream1, stream2, ... streamN])
|
|||
|
|
|||
|
Append streams given in argument to the queue and ends when the queue is empty.
|
|||
|
|
|||
|
## Stats
|
|||
|
|
|||
|
[data:image/s3,"s3://crabby-images/4b62c/4b62c117c1111f4f762671dd21856f6c57f0930c" alt="NPM"](https://nodei.co/npm/streamqueue/)
|
|||
|
[data:image/s3,"s3://crabby-images/fc9d5/fc9d5e5f46629dc5b303db39b31fb54ca3c57ddb" alt="NPM"](https://nodei.co/npm/streamqueue/)
|
|||
|
|
|||
|
|
|||
|
## Contributing
|
|||
|
Feel free to pull your code if you agree with publishing it under the MIT license.
|
|||
|
|