xen-orchestra/@vates/disposable
2023-11-28 09:30:32 +01:00
..
.npmignore feat: unified .npmignore for all packages 2021-04-07 13:58:14 +02:00
.USAGE.md chore: hide USAGE.md 2022-02-18 17:11:52 +01:00
debounceResource.js chore: enforce strict mode for CJS files 2022-02-22 12:34:41 +01:00
debounceResource.test.js test: remove unnecessary ESLint comments (#6479) 2022-10-24 17:46:27 +02:00
deduped.js chore: enforce strict mode for CJS files 2022-02-22 12:34:41 +01:00
deduped.test.js test: remove unnecessary ESLint comments (#6479) 2022-10-24 17:46:27 +02:00
package.json feat: technical release (#7208) 2023-11-28 09:30:32 +01:00
README.md docs: uniformize code blocks 2023-02-06 11:25:12 +01:00

@vates/disposable

Package Version License PackagePhobia Node compatibility

Utilities for disposables

Install

Installation of the npm package:

npm install --save @vates/disposable

Usage

This library contains utilities for disposables as defined by the promise-toolbox library.

deduped(fn, keyFn)

Creates a new function that wraps fn and instead of creating a new disposables at each call, returns copies of the same one when keyFn returns the same keys.

Those copies contains the same value and can be disposed independently, the source disposable will only be disposed when all copies are disposed.

keyFn is called with the same context and arguments as the wrapping function and must returns an array of keys which will be used to identify which disposables should be grouped together.

import { deduped } from '@vates/disposable/deduped'

// the connection with the passed host will be established once at the first call, then, it will be shared with the next calls
const getConnection = deduped(async function (host)) {
  const connection = new Connection(host)
  return new Disposabe(connection, () => connection.close())
}, host => [host])

debounceResource(disposable, delay)

Creates a new disposable with the same value and with a delayed disposer.

On calling this disposer, the source disposable will be disposed when the delay is passed.

import { createDebounceResource } from '@vates/disposable/debounceResource'

const debounceResource = createDebounceResource()

// it will wait for 10 seconds before calling the disposer
Disposable.use(debounceResource(getConnection(host), 10e3), connection => {})

debounceResource.flushAll()

Disposes all delayed disposers and cancels the delaying of the disposables that are in usage.

import { createDebounceResource } from '@vates/disposable/debounceResource'

const debounceResource = createDebounceResource()

const res1 = await debounceResource(res, 10e3)
const res2 = await debounceResource(res, 10e3)
const res3 = await debounceResource(res, 10e3)

rest1.dispose()
rest2.dispose()
// res3 is in usage

debounceResource.flushAll()
// res1 and res2 are immediately disposed
// res3 will be disposed immediately when its disposer will be called

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