• Home
Name Date Size #Lines LOC

..--

LICENSED12-May-2024765 1612

README.mdD12-May-20241.7 KiB8060

once.jsD12-May-2024935 4338

package.jsonD12-May-20241.6 KiB8180

README.md

1# once
2
3Only call a function once.
4
5## usage
6
7```javascript
8var once = require('once')
9
10function load (file, cb) {
11  cb = once(cb)
12  loader.load('file')
13  loader.once('load', cb)
14  loader.once('error', cb)
15}
16```
17
18Or add to the Function.prototype in a responsible way:
19
20```javascript
21// only has to be done once
22require('once').proto()
23
24function load (file, cb) {
25  cb = cb.once()
26  loader.load('file')
27  loader.once('load', cb)
28  loader.once('error', cb)
29}
30```
31
32Ironically, the prototype feature makes this module twice as
33complicated as necessary.
34
35To check whether you function has been called, use `fn.called`. Once the
36function is called for the first time the return value of the original
37function is saved in `fn.value` and subsequent calls will continue to
38return this value.
39
40```javascript
41var once = require('once')
42
43function load (cb) {
44  cb = once(cb)
45  var stream = createStream()
46  stream.once('data', cb)
47  stream.once('end', function () {
48    if (!cb.called) cb(new Error('not found'))
49  })
50}
51```
52
53## `once.strict(func)`
54
55Throw an error if the function is called twice.
56
57Some functions are expected to be called only once. Using `once` for them would
58potentially hide logical errors.
59
60In the example below, the `greet` function has to call the callback only once:
61
62```javascript
63function greet (name, cb) {
64  // return is missing from the if statement
65  // when no name is passed, the callback is called twice
66  if (!name) cb('Hello anonymous')
67  cb('Hello ' + name)
68}
69
70function log (msg) {
71  console.log(msg)
72}
73
74// this will print 'Hello anonymous' but the logical error will be missed
75greet(null, once(msg))
76
77// once.strict will print 'Hello anonymous' and throw an error when the callback will be called the second time
78greet(null, once.strict(msg))
79```
80