async-iterator-to-stream
Convert an async iterator/iterable to a readable stream
Even though this library is dedicated to async iterators, it is fully
compatible with synchronous ones.
Furthermore, generators can be used to create readable stream factories!
Install
Installation of the npm package:
> npm install --save async-iterator-to-stream
Usage
const asyncIteratorToStream = require('async-iterator-to-stream')
asyncIteratorToStream(new Set(['foo', 'bar']).values())
.pipe(output)
asyncIteratorToStream.obj([1, 2, 3])
.pipe(output)
const createRangeStream = asyncIteratorToStream.obj(function * (n) {
for (let i = 0; i < n; ++i) {
yield i
}
})
createRangeStream(10)
.pipe(output)
Example
Let's implement a simpler fs.createReadStream
to illustrate the usage of this
library.
const asyncIteratorToStream = require('async-iterator-to-stream')
const fs = require('mz/fs')
const createReadStream = asyncIteratorToStream(async function * (file) {
const fd = await fs.open(file, 'r')
try {
let size = yield
while (true) {
const buf = Buffer.alloc(size)
const [n] = await fs.read(fd, buf, 0, size, null)
if (n < size) {
yield buf.slice(0, n)
return
}
size = yield buf
}
} finally {
await fs.close(fd)
}
})
createReadStream('foo.txt').pipe(process.stdout)
If your environment does not support async generators, you may use a sync
generator instead and yield
promises to wait for them.
Development
# Install dependencies
> yarn
# Run the tests
> yarn test
# Continuously compile
> yarn dev
# Continuously run the tests
> yarn dev-test
# Build for production
> yarn build
Contributions
Contributions are very welcomed, either on the documentation or on
the code.
You may:
- report any issue
you've encountered;
- fork and create a pull request.
License
ISC © Julien Fontanet