xen-orchestra/@vates/async-each
2024-02-02 12:52:11 +01:00
..
.npmignore feat(async-each): run async fn for each item in (async) iterable 2021-11-17 22:27:43 +01:00
.USAGE.md feat(async-each): change default concurrency to 10 2022-07-05 12:00:07 +02:00
index.js feat(async-each): change default concurrency to 10 2022-07-05 12:00:07 +02:00
index.test.js test(async-each): fix iteratee calls 2022-10-25 13:14:44 +02:00
package.json chore(async-each): remove unused dev dep tap 2024-02-02 12:52:11 +01:00
README.md docs: uniformize code blocks 2023-02-06 11:25:12 +01:00

@vates/async-each

Package Version License PackagePhobia Node compatibility

Run async fn for each item in (async) iterable

Install

Installation of the npm package:

npm install --save @vates/async-each

Usage

asyncEach(iterable, iteratee, [opts])

Executes iteratee in order for each value yielded by iterable.

Returns a promise wich rejects as soon as a call to iteratee throws or a promise returned by it rejects, and which resolves when all promises returned by iteratee have resolved.

iterable must be an iterable or async iterable.

iteratee is called with the same this value as asyncEach, and with the following arguments:

  • value: the value yielded by iterable
  • index: the 0-based index for this value
  • iterable: the iterable itself

opts is an object that can contains the following options:

  • concurrency: a number which indicates the maximum number of parallel call to iteratee, defaults to 10. The value 0 means no concurrency limit.
  • signal: an abort signal to stop the iteration
  • stopOnError: wether to stop iteration of first error, or wait for all calls to finish and throw an AggregateError, defaults to true
import { asyncEach } from '@vates/async-each'

const contents = []
await asyncEach(
  ['foo.txt', 'bar.txt', 'baz.txt'],
  async function (filename, i) {
    contents[i] = await readFile(filename)
  },
  {
    // reads two files at a time
    concurrency: 2,
  }
)

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 © Vates SAS