Files: d99d85a16533a82af15af59ea09e68058f746596 / docs / pull.md
pull-stream/pull
pipe many pull streams into a pipeline
Background
In pull-streams, you need a complete pipeline before data will flow.
That means: a source, zero or more throughs, and a sink.
But you can still create a partial pipeline, which is a great for tiny pull-stream modules.
Usage
var pull = require('pull-stream/pull')
Create a simple complete pipeline:
pull(source, sink) => undefined
Create a source modified by a through:
pull(source, through) => source
Create a sink, but modify it's input before it goes.
pull(through, sink) => sink
Create a through, by chainging several throughs:
pull(through1, through2) => through
These streams combine just like normal streams.
pull(
pull(source, through),
pull(through1, through2),
pull(through, sink)
) => undefined
The complete pipeline returns undefined, because it cannot be piped to anything else.
Pipe duplex streams like this:
var a = duplex()
var b = duplex()
pull(a.source, b.sink)
pull(b.source, a.sink)
//which is the same as
b.sink(a.source); a.sink(b.source)
//but the easiest way is to allow pull to handle this
pull(a, b, a)
//"pull from a to b and then back to a"
API
var pull = require('pull-stream/pull')
pull(...streams)
pull
is a function that receives n-arity stream arguments and connects them into a pipeline.
pull
detects the type of stream by checking function arity, if the function takes only one argument it's either a sink or a through. Otherwise it's a source. A duplex stream is an object with the shape { source, sink }
.
If the pipeline is complete (reduces into a source being passed into a sink), then pull
returns undefined
, as the data is flowing.
If the pipeline is partial (reduces into either a source, a through, or a sink), then pull
returns the partial pipeline, as it must be composed with other streams before the data will flow.
Install
With npm installed, run
$ npm install pull-stream
See Also
License
Built with git-ssb-web