Sha256: f97f713a83538724513d50faa561ba6aa5fb452b81a9bf1dc937efc20fcafec7

Contents?: true

Size: 1.41 KB

Versions: 98

Compression:

Stored size: 1.41 KB

Contents

# pump

pump is a small node module that pipes streams together and destroys all of them if one of them closes.

```
npm install pump
```

[![build status](http://img.shields.io/travis/mafintosh/pump.svg?style=flat)](http://travis-ci.org/mafintosh/pump)

## What problem does it solve?

When using standard `source.pipe(dest)` source will _not_ be destroyed if dest emits close or an error.
You are also not able to provide a callback to tell when then pipe has finished.

pump does these two things for you

## Usage

Simply pass the streams you want to pipe together to pump and add an optional callback

``` js
var pump = require('pump')
var fs = require('fs')

var source = fs.createReadStream('/dev/random')
var dest = fs.createWriteStream('/dev/null')

pump(source, dest, function(err) {
  console.log('pipe finished', err)
})

setTimeout(function() {
  dest.destroy() // when dest is closed pump will destroy source
}, 1000)
```

You can use pump to pipe more than two streams together as well

``` js
var transform = someTransformStream()

pump(source, transform, anotherTransform, dest, function(err) {
  console.log('pipe finished', err)
})
```

If `source`, `transform`, `anotherTransform` or `dest` closes all of them will be destroyed.

## License

MIT

## Related

`pump` is part of the [mississippi stream utility collection](https://github.com/maxogden/mississippi) which includes more useful stream modules similar to this one.

Version data entries

98 entries across 96 versions & 13 rubygems

Version Path
ilog-0.4.0 node_modules/pump/README.md
ilog-0.3.3 node_modules/pump/README.md
jester-data-8.0.0 node_modules/pumpify/node_modules/pump/README.md
ezii-os-5.2.1 node_modules/pumpify/node_modules/pump/README.md
ezii-os-2.0.1 node_modules/pumpify/node_modules/pump/README.md
ezii-os-1.1.0 node_modules/pumpify/node_modules/pump/README.md
ezii-os-1.0.0 node_modules/pumpify/node_modules/pump/README.md
ezii-os-0.0.0.1.0 node_modules/pumpify/node_modules/pump/README.md
ezii-os-0.0.0.0.1 node_modules/pumpify/node_modules/pump/README.md
optimacms-0.4.3 spec/dummy/node_modules/pump/README.md
optimacms-0.4.2 spec/dummy/node_modules/pump/README.md
locomotivecms-4.0.0.alpha1 app/javascript/node_modules/pump/README.md
locomotivecms-3.4.0 app/javascript/node_modules/pump/README.md
cortex-0.1.3 spec/dummy/node_modules/pumpify/node_modules/pump/README.md
cortex-0.1.3 spec/dummy/node_modules/pump/README.md
dragonfly_puppeteer-0.1.0 node_modules/pump/README.md
trusty-festivity-extension-2.6.3 node_modules/bower/node_modules/tar-fs/node_modules/pump/README.md
trusty-festivity-extension-2.6.2 node_modules/bower/node_modules/tar-fs/node_modules/pump/README.md
trusty-festivity-extension-2.6.1 node_modules/bower/node_modules/tar-fs/node_modules/pump/README.md
trusty-festivity-extension-2.6 node_modules/bower/node_modules/tar-fs/node_modules/pump/README.md