mirror of
https://github.com/azure/login.git
synced 2026-03-15 09:20:56 -04:00
* Bump lodash from 4.17.15 to 4.17.19 (#52) Bumps [lodash](https://github.com/lodash/lodash) from 4.17.15 to 4.17.19. - [Release notes](https://github.com/lodash/lodash/releases) - [Commits](https://github.com/lodash/lodash/compare/4.17.15...4.17.19) Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Amruta Kawade <65217380+AmrutaKawade@users.noreply.github.com> * Bump @actions/core from 1.1.3 to 1.2.6 (#60) Bumps [@actions/core](https://github.com/actions/toolkit/tree/HEAD/packages/core) from 1.1.3 to 1.2.6. - [Release notes](https://github.com/actions/toolkit/releases) - [Changelog](https://github.com/actions/toolkit/blob/main/packages/core/RELEASES.md) - [Commits](https://github.com/actions/toolkit/commits/HEAD/packages/core) Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Amruta Kawade <65217380+AmrutaKawade@users.noreply.github.com> * updating node_nodules * updated package-lock Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
80 lines
1.7 KiB
Markdown
80 lines
1.7 KiB
Markdown
# once
|
|
|
|
Only call a function once.
|
|
|
|
## usage
|
|
|
|
```javascript
|
|
var once = require('once')
|
|
|
|
function load (file, cb) {
|
|
cb = once(cb)
|
|
loader.load('file')
|
|
loader.once('load', cb)
|
|
loader.once('error', cb)
|
|
}
|
|
```
|
|
|
|
Or add to the Function.prototype in a responsible way:
|
|
|
|
```javascript
|
|
// only has to be done once
|
|
require('once').proto()
|
|
|
|
function load (file, cb) {
|
|
cb = cb.once()
|
|
loader.load('file')
|
|
loader.once('load', cb)
|
|
loader.once('error', cb)
|
|
}
|
|
```
|
|
|
|
Ironically, the prototype feature makes this module twice as
|
|
complicated as necessary.
|
|
|
|
To check whether you function has been called, use `fn.called`. Once the
|
|
function is called for the first time the return value of the original
|
|
function is saved in `fn.value` and subsequent calls will continue to
|
|
return this value.
|
|
|
|
```javascript
|
|
var once = require('once')
|
|
|
|
function load (cb) {
|
|
cb = once(cb)
|
|
var stream = createStream()
|
|
stream.once('data', cb)
|
|
stream.once('end', function () {
|
|
if (!cb.called) cb(new Error('not found'))
|
|
})
|
|
}
|
|
```
|
|
|
|
## `once.strict(func)`
|
|
|
|
Throw an error if the function is called twice.
|
|
|
|
Some functions are expected to be called only once. Using `once` for them would
|
|
potentially hide logical errors.
|
|
|
|
In the example below, the `greet` function has to call the callback only once:
|
|
|
|
```javascript
|
|
function greet (name, cb) {
|
|
// return is missing from the if statement
|
|
// when no name is passed, the callback is called twice
|
|
if (!name) cb('Hello anonymous')
|
|
cb('Hello ' + name)
|
|
}
|
|
|
|
function log (msg) {
|
|
console.log(msg)
|
|
}
|
|
|
|
// this will print 'Hello anonymous' but the logical error will be missed
|
|
greet(null, once(msg))
|
|
|
|
// once.strict will print 'Hello anonymous' and throw an error when the callback will be called the second time
|
|
greet(null, once.strict(msg))
|
|
```
|