Asynchronous lock utilities.
JavaScript exposes the ability to create interleaved execution of asynchronous operations. When this is done with shared state between asynchronous overlapping functions that perform partial state transitions, this can lead to race conditions or data corruption and clobbering, or just invalid pre-condition or post-condition behaviour.
This library provides multiple synchronization constructs that allow one to precisely control concurrent operations. These constructs are intended for pessimistic concurrency control. If you can prefer to use optimistic concurrency control mechanisms. But that is outside the scope of this library. In many cases you cannot use optimistic methods, and thus you need this library.
npm install --save @matrixai/async-locks
Run nix-shell
, and once you're inside, you can use:
# install (or reinstall packages from package.json)
npm install
# build the dist
npm run build
# run the repl (this allows you to import from ./src)
npm run tsx
# run the tests
npm run test
# lint the source code
npm run lint
# automatically fix the source
npm run lintfix
npm run docs
See the docs at: https://matrixai.github.io/js-async-locks/
Publishing is handled automatically by the staging pipeline.
Prerelease:
# npm login
npm version prepatch --preid alpha # premajor/preminor/prepatch
git push --follow-tags
Release:
# npm login
npm version patch # major/minor/patch
git push --follow-tags
Manually:
# npm login
npm version patch # major/minor/patch
npm run build
npm publish --access public
git push
git push --tags