Skip to content

magicdawn/promise.map

Repository files navigation

promise.map

Promise.map

Build Status Coverage Status npm version npm downloads npm license

Install

$ npm i -S promise.map

API

pmap

declare function pmap<IN, OUT>(
  arr: IN[],
  fn: (item: IN, index: number, arr: IN[]) => Promise<OUT> | OUT,
  concurrency: number,
): Promise<OUT[]>

declare namespace pmap {
  export function pmapWorker<IN, OUT, AnyWorker extends Object>(
    arr: IN[],
    fn: (item: IN, index: number, arr: IN[], worker: AnyWorker) => Promise<OUT>,
    workers: AnyWorker[],
  ): Promise<OUT[]>
}

export = pmap
var p = pmap(
  arr,
  function (item, index, arr) {
    return getOtherPromise(item)
  },
  concurrency,
)

map on Workers: pmapWorker

for cpu heavy work, you can map on workers (WebWorker / Node.js worker_threads)

export function pmapWorker<IN, OUT, AnyWorker extends Object>(
  arr: IN[],
  fn: (item: IN, index: number, arr: IN[], worker: AnyWorker) => Promise<OUT>,
  workers: AnyWorker[],
): Promise<OUT[]>

Why

  • bluebird is awesome, and provide tons of convience methods, such as Promise.map, it provides async.parallelLimit but, it got some opinioned ways, like this warn. So we'd better split things out.
  • package promise-map simply use Array.prototype.map, that lost a concurrency or parallelLimit control
  • earlier than p-map

See Also

Changelog

CHANGELOG.md

License

the MIT License http://magicdawn.mit-license.org