-
Notifications
You must be signed in to change notification settings - Fork 5
Asynchronous Iterables
Asynchronous Iterables are fully supported by the library, with some considerations, as below.
The library enforces consistency of the pipeline result with the source iterable type:
- When the source iterable is synchronous, the end result is also synchronous
- When the source iterable is asynchronous, the end result is also asynchronous
Some operators (concat
, defaultEmpty
, aggregate
) make it possible to violate the first item, because they either accept both synchronous and asynchronous iterables, or can return such. When the source iterable of the pipeline is synchronous, and you inject asynchronous iterables (by mistake), the pipeline result will still be cast as synchronous, while the asynchronous iterables will be processed as simple values, and not as iterables.
Note that the opposite isn't true, i.e. when the source iterable is asynchronous, you can inject both synchronous and asynchronous iterables, and all will be processed correctly, because addition of synchronous iterables to an asynchronous pipeline doesn't change anything, they will work fine alongside asynchronous iterables.
To use asynchronous operators inside a synchronous pipeline, use toAsync to make the source asynchronous.
Example
import {pipe, toAsync, delay} from 'iter-ops';
const values = [1, 2, 3, 4, 5];
const i = pipe(
toAsync(values), // make the source asynchronous
delay(1000)
);
for await(const a of i) {
console.log(a); // will show numbers with 1s delay between them
}