node/deps/npm/node_modules/once
Rebecca Turner c54d057598 deps: upgrade to npm 2.10.1
PR-URL: https://github.com/nodejs/io.js/pull/1763
Reviewed-By: Jeremiah Senkpiel <fishrock123@rocketmail.com>
2015-05-23 19:48:00 -04:00
..
test npm: Upgrade to v2.1.6 2014-11-05 10:35:43 -08:00
LICENSE deps: upgrade to npm 2.10.1 2015-05-23 19:48:00 -04:00
README.md npm@1.3.12 2013-10-24 09:22:13 -07:00
once.js npm: Upgrade to v2.1.6 2014-11-05 10:35:43 -08:00
package.json deps: upgrade to npm 2.10.1 2015-05-23 19:48:00 -04:00

README.md

once

Only call a function once.

usage

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:

// 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.

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'))
  })
}