34 lines
1.0 KiB
Markdown
34 lines
1.0 KiB
Markdown
|
# stream-exhaust
|
||
|
|
||
|
Ensure that the provided stream is flowing data, even if the stream hasn't been
|
||
|
piped to another stream.
|
||
|
|
||
|
```javascript
|
||
|
var exhaustively = require('stream-exhaust');
|
||
|
|
||
|
exhaustively(fs.createReadStream(__filename))
|
||
|
.on('close', () => { console.log('all done, despite being streams{1+N}!') });
|
||
|
```
|
||
|
|
||
|
## Prior Art
|
||
|
|
||
|
This is based on [stream-consume](https://github.com/aroneous/stream-consume)
|
||
|
by [aroneous](https://github.com/aroneous). It is a separate package because it has
|
||
|
different semantics:
|
||
|
|
||
|
1. It does not call `.resume()` on streams2+ streams. streams2 streams monkeypatch `.pipe`
|
||
|
when entering flowing mode; avoiding `resume()` avoids that fate.
|
||
|
2. It does not examine `._readableState`; instead it checks for the presence of `._read`.
|
||
|
|
||
|
## API
|
||
|
|
||
|
### exhaust(Stream s) -> Stream s
|
||
|
|
||
|
Takes a stream, `s`, and returns it. Ensures that the stream is flowing, either by calling
|
||
|
`.resume()` if the stream is a streams1 stream, or by piping it to a "black hole" stream that
|
||
|
continually asks for more data.
|
||
|
|
||
|
## License
|
||
|
|
||
|
MIT
|