Find a file
2024-07-20 14:01:17 +02:00
.gitignore Initial commit 2020-07-20 23:06:56 +02:00
example.js Update to new name 2021-03-02 13:21:16 +01:00
index.js Upgrade @promistream/simple-sink 2024-07-20 14:01:11 +02:00
package.json 0.1.2 2024-07-20 14:01:17 +02:00
pnpm-lock.yaml Upgrade @promistream/simple-sink 2024-07-20 14:01:11 +02:00
README.md Update to new name 2021-03-02 13:21:16 +01:00

@promistream/collect

This is a sink stream that's used to collect the results of a pipeline into a single array.

When its read method is called, this stream returns a Promise and then just endlessly reads from its source stream until it receives an EndOfStream. Once the source stream ends, the Promise is resolved with an array containing every value that the collect stream has received.

Example

"use strict";

const Promise = require("bluebird");
const pipe = require("@promistream/pipe");
const rangeNumbers = require("@promistream/range-numbers");
const collect = require("@promistream/collect");

return Promise.try(() => {
	return pipe([
		rangeNumbers(0, 20),
		collect()
	]).read();
}).then((result) => {
	console.log(result);
	// [ 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19 ]
});

API

collect()

Returns a new collect stream. Takes no arguments.

Stream behaviour:

  • Reads from source: Infinitely, until the end of the source stream is reached.
  • Consumes: Values of any kind.
  • Produces: Returns a Promise when .read() is called, that will resolve with accumulated values received from the source stream when its end is reached, or reject when an error of any kind (including an Aborted marker) is received from the source stream.
  • Throws: Only when an error is received from upstream.
  • Aborts: Never.