Detalhes do pacote

native-promise-pool

bevry1.5kArtistic-2.03.28.0

Create a pool of a specified concurrency that accepts functions that return promises

async, browser, concurrency, deno

readme (leia-me)

native-promise-pool

Status of the GitHub Workflow: bevry NPM version NPM downloads
GitHub Sponsors donate button ThanksDev donate button Patreon donate button Liberapay donate button Buy Me A Coffee donate button Open Collective donate button crypto donate button PayPal donate button
Discord server badge Twitch community badge

Create a pool of a specified concurrency that accepts functions that return promises

Usage

Complete API Documentation.

To use, just make a promise pool with the specified concurrency, then wrap the method in a pool.open(() => /* the code that you want pooled */). The callback is necessary, as otherwise the code that you want pooled will execute before it is pooled. By pooling it, it executes once the pool entry is called.

import PromisePool from 'native-promise-pool'
const pool = new PromisePool(2) // 5 tasks at once
await Promise.all([
    pool.open(() => /* the thing that takes a while */)
    pool.open(() => /* the thing that takes a while */)
    pool.open(() => /* the thing that takes a while, will run after the first two have completed */)
])

Table Example

Table Example Preview.

Table Example Source.

Simple Example

Simple Example Preview.

Simple Example Source.

Await Example

Await Example Preview.

Await Example Source.

Finally

This package depends on Promise.prototype.finally existing, which it does on Node v10 and above.

On older environments, you must use a shim, like so:

require('promise.prototype.finally').shim()
const pool = require('native-promise-pool').create({ concurrency: 2 })

Install

npm

  • Install: npm install --save native-promise-pool
  • Import: import pkg from ('native-promise-pool')
  • Require: const pkg = require('native-promise-pool').default

Deno

import pkg from 'https://unpkg.com/native-promise-pool@^3.28.0/edition-deno/index.ts'

Skypack

<script type="module">
    import pkg from '//cdn.skypack.dev/native-promise-pool@^3.28.0'
</script>

unpkg

<script type="module">
    import pkg from '//unpkg.com/native-promise-pool@^3.28.0'
</script>

jspm

<script type="module">
    import pkg from '//dev.jspm.io/native-promise-pool@3.28.0'
</script>

Editions

This package is published with the following editions:

  • native-promise-pool aliases native-promise-pool/index.cjs which uses the Editions Autoloader to automatically select the correct edition for the consumer's environment
  • native-promise-pool/source/index.ts is TypeScript source code with Import for modules
  • native-promise-pool/edition-browsers/index.js is TypeScript compiled against ES2022 for web browsers with Import for modules
  • native-promise-pool/edition-es2022/index.js is TypeScript compiled against ES2022 for Node.js 12 || 14 || 16 || 18 || 20 || 21 with Require for modules
  • native-promise-pool/edition-es2016/index.js is TypeScript compiled against ES2016 for Node.js 10 || 12 || 14 || 16 || 18 || 20 || 21 with Require for modules
  • native-promise-pool/edition-es2022-esm/index.js is TypeScript compiled against ES2022 for Node.js 12 || 14 || 16 || 18 || 20 || 21 with Import for modules
  • native-promise-pool/edition-types/index.d.ts is TypeScript compiled Types with Import for modules
  • native-promise-pool/edition-deno/index.ts is TypeScript source code made to be compatible with Deno

History

Discover the release history by heading on over to the HISTORY.md file.

Backers

Code

Discover how to contribute via the CONTRIBUTING.md file.

Authors

Maintainers

Contributors

Finances

GitHub Sponsors donate button ThanksDev donate button Patreon donate button Liberapay donate button Buy Me A Coffee donate button Open Collective donate button crypto donate button PayPal donate button

Sponsors

  • Andrew Nesbitt — Software engineer and researcher
  • Balsa — We're Balsa, and we're building tools for builders.
  • Codecov — Empower developers with tools to improve code quality and testing.
  • Poonacha Medappa
  • Rob Morris
  • Sentry — Real-time crash reporting for your web apps, mobile apps, and games.
  • Syntax — Syntax Podcast

Donors

License

Unless stated otherwise all works are:

and licensed under:

changelog (log de mudanças)

History

v3.28.0 2023 December 30

v3.27.0 2023 December 28

v3.26.0 2023 December 6

v3.25.0 2023 November 25

v3.24.0 2023 November 21

v3.23.0 2023 November 15

v3.22.0 2023 November 14

v3.21.0 2023 November 13

v3.20.0 2023 November 2

v3.19.0 2021 July 30

v3.18.0 2021 July 29

v3.17.0 2021 July 28

v3.16.0 2020 October 29

v3.15.0 2020 September 5

v3.14.0 2020 August 18

v3.13.0 2020 August 4

v3.12.0 2020 July 22

v3.11.0 2020 June 25

v3.10.0 2020 June 22

v3.9.0 2020 June 21

v3.8.0 2020 June 20

v3.7.0 2020 June 11

v3.6.0 2020 June 10

v3.5.0 2020 May 22

v3.4.0 2020 May 21

v3.3.0 2020 May 21

v3.2.0 2020 May 11

  • Support concurrency of 0 for unlimited concurrency

v3.1.0 2020 May 11

v3.0.0 2020 April 19

  • Rewrote in TypeScript
  • new PromisePool({concurrency}) has changed to new PromisePool(concurrency)
  • Support for specifying the promise class has been removed now that Node v10 is now the minimum supported LTS version
  • Updated dependencies, base files, and editions using boundation

v2.3.0 2019 December 10

v2.2.0 2019 December 1

v2.1.0 2019 December 1

v2.0.0 2019 November 18

  • Updated dependencies, base files, and editions using boundation
  • Minimum required node version changed from node: >=6 to node: >=8 to keep up with mandatory ecosystem changes

v1.2.0 2019 November 13

v1.1.0 2019 November 9

v1.0.0 2018 November 14

  • Initial stable release