pax_global_header00006660000000000000000000000064127052264020014512gustar00rootroot0000000000000052 comment=187492ab8028c7221b589bdfd482b715149cd868 emitter-1.2.1/000077500000000000000000000000001270522640200131645ustar00rootroot00000000000000emitter-1.2.1/.gitignore000066400000000000000000000000151270522640200151500ustar00rootroot00000000000000node_modules emitter-1.2.1/.travis.yml000066400000000000000000000000761270522640200153000ustar00rootroot00000000000000node_js: - "0.8" - "0.10" - "0.12" - "iojs" language: node_js emitter-1.2.1/History.md000066400000000000000000000023701270522640200151510ustar00rootroot00000000000000 1.2.1 / 2016-04-18 ================== * enable client side use 1.2.0 / 2014-02-12 ================== * prefix events with `$` to support object prototype method names 1.1.3 / 2014-06-20 ================== * republish for npm * add LICENSE file 1.1.2 / 2014-02-10 ================== * package: rename to "component-emitter" * package: update "main" and "component" fields * Add license to Readme (same format as the other components) * created .npmignore * travis stuff 1.1.1 / 2013-12-01 ================== * fix .once adding .on to the listener * docs: Emitter#off() * component: add `.repo` prop 1.1.0 / 2013-10-20 ================== * add `.addEventListener()` and `.removeEventListener()` aliases 1.0.1 / 2013-06-27 ================== * add support for legacy ie 1.0.0 / 2013-02-26 ================== * add `.off()` support for removing all listeners 0.0.6 / 2012-10-08 ================== * add `this._callbacks` initialization to prevent funky gotcha 0.0.5 / 2012-09-07 ================== * fix `Emitter.call(this)` usage 0.0.3 / 2012-07-11 ================== * add `.listeners()` * rename `.has()` to `.hasListeners()` 0.0.2 / 2012-06-28 ================== * fix `.off()` with `.once()`-registered callbacks emitter-1.2.1/LICENSE000066400000000000000000000021201270522640200141640ustar00rootroot00000000000000(The MIT License) Copyright (c) 2014 Component contributors Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. emitter-1.2.1/Makefile000066400000000000000000000001311270522640200146170ustar00rootroot00000000000000 test: @./node_modules/.bin/mocha \ --require should \ --reporter spec .PHONY: testemitter-1.2.1/Readme.md000066400000000000000000000025341270522640200147070ustar00rootroot00000000000000# Emitter [![Build Status](https://travis-ci.org/component/emitter.png)](https://travis-ci.org/component/emitter) Event emitter component. ## Installation ``` $ component install component/emitter ``` ## API ### Emitter(obj) The `Emitter` may also be used as a mixin. For example a "plain" object may become an emitter, or you may extend an existing prototype. As an `Emitter` instance: ```js var Emitter = require('emitter'); var emitter = new Emitter; emitter.emit('something'); ``` As a mixin: ```js var Emitter = require('emitter'); var user = { name: 'tobi' }; Emitter(user); user.emit('im a user'); ``` As a prototype mixin: ```js var Emitter = require('emitter'); Emitter(User.prototype); ``` ### Emitter#on(event, fn) Register an `event` handler `fn`. ### Emitter#once(event, fn) Register a single-shot `event` handler `fn`, removed immediately after it is invoked the first time. ### Emitter#off(event, fn) * Pass `event` and `fn` to remove a listener. * Pass `event` to remove all listeners on that event. * Pass nothing to remove all listeners on all events. ### Emitter#emit(event, ...) Emit an `event` with variable option args. ### Emitter#listeners(event) Return an array of callbacks, or an empty array. ### Emitter#hasListeners(event) Check if this emitter has `event` handlers. ## License MIT emitter-1.2.1/bower.json000066400000000000000000000005621270522640200152000ustar00rootroot00000000000000{ "name": "emitter", "description": "Event emitter", "keywords": [ "emitter", "events" ], "version": "1.2.1", "license": "MIT", "main": "index.js", "homepage": "https://github.com/component/emitter", "ignore": [ "**/.*", "node_modules", "bower_components", "test", "Makefile", "package.json", "component.json" ] } emitter-1.2.1/component.json000066400000000000000000000003271270522640200160630ustar00rootroot00000000000000{ "name": "emitter", "repo": "component/emitter", "description": "Event emitter", "keywords": [ "emitter", "events" ], "version": "1.2.0", "scripts": [ "index.js" ], "license": "MIT" } emitter-1.2.1/index.js000066400000000000000000000057121270522640200146360ustar00rootroot00000000000000 /** * Expose `Emitter`. */ if (typeof module !== 'undefined') { module.exports = Emitter; } /** * Initialize a new `Emitter`. * * @api public */ function Emitter(obj) { if (obj) return mixin(obj); }; /** * Mixin the emitter properties. * * @param {Object} obj * @return {Object} * @api private */ function mixin(obj) { for (var key in Emitter.prototype) { obj[key] = Emitter.prototype[key]; } return obj; } /** * Listen on the given `event` with `fn`. * * @param {String} event * @param {Function} fn * @return {Emitter} * @api public */ Emitter.prototype.on = Emitter.prototype.addEventListener = function(event, fn){ this._callbacks = this._callbacks || {}; (this._callbacks['$' + event] = this._callbacks['$' + event] || []) .push(fn); return this; }; /** * Adds an `event` listener that will be invoked a single * time then automatically removed. * * @param {String} event * @param {Function} fn * @return {Emitter} * @api public */ Emitter.prototype.once = function(event, fn){ function on() { this.off(event, on); fn.apply(this, arguments); } on.fn = fn; this.on(event, on); return this; }; /** * Remove the given callback for `event` or all * registered callbacks. * * @param {String} event * @param {Function} fn * @return {Emitter} * @api public */ Emitter.prototype.off = Emitter.prototype.removeListener = Emitter.prototype.removeAllListeners = Emitter.prototype.removeEventListener = function(event, fn){ this._callbacks = this._callbacks || {}; // all if (0 == arguments.length) { this._callbacks = {}; return this; } // specific event var callbacks = this._callbacks['$' + event]; if (!callbacks) return this; // remove all handlers if (1 == arguments.length) { delete this._callbacks['$' + event]; return this; } // remove specific handler var cb; for (var i = 0; i < callbacks.length; i++) { cb = callbacks[i]; if (cb === fn || cb.fn === fn) { callbacks.splice(i, 1); break; } } return this; }; /** * Emit `event` with the given args. * * @param {String} event * @param {Mixed} ... * @return {Emitter} */ Emitter.prototype.emit = function(event){ this._callbacks = this._callbacks || {}; var args = [].slice.call(arguments, 1) , callbacks = this._callbacks['$' + event]; if (callbacks) { callbacks = callbacks.slice(0); for (var i = 0, len = callbacks.length; i < len; ++i) { callbacks[i].apply(this, args); } } return this; }; /** * Return array of callbacks for `event`. * * @param {String} event * @return {Array} * @api public */ Emitter.prototype.listeners = function(event){ this._callbacks = this._callbacks || {}; return this._callbacks['$' + event] || []; }; /** * Check if this emitter has `event` handlers. * * @param {String} event * @return {Boolean} * @api public */ Emitter.prototype.hasListeners = function(event){ return !! this.listeners(event).length; }; emitter-1.2.1/package.json000066400000000000000000000007061270522640200154550ustar00rootroot00000000000000{ "name": "component-emitter", "description": "Event emitter", "version": "1.2.1", "license": "MIT", "devDependencies": { "mocha": "*", "should": "*" }, "component": { "scripts": { "emitter/index.js": "index.js" } }, "main": "index.js", "repository": { "type": "git", "url": "https://github.com/component/emitter.git" }, "scripts": { "test": "make test" }, "files": ["index.js", "LICENSE"] } emitter-1.2.1/test/000077500000000000000000000000001270522640200141435ustar00rootroot00000000000000emitter-1.2.1/test/emitter.js000066400000000000000000000116021270522640200161520ustar00rootroot00000000000000 var Emitter = require('..'); function Custom() { Emitter.call(this) } Custom.prototype.__proto__ = Emitter.prototype; describe('Custom', function(){ describe('with Emitter.call(this)', function(){ it('should work', function(done){ var emitter = new Custom; emitter.on('foo', done); emitter.emit('foo'); }) }) }) describe('Emitter', function(){ describe('.on(event, fn)', function(){ it('should add listeners', function(){ var emitter = new Emitter; var calls = []; emitter.on('foo', function(val){ calls.push('one', val); }); emitter.on('foo', function(val){ calls.push('two', val); }); emitter.emit('foo', 1); emitter.emit('bar', 1); emitter.emit('foo', 2); calls.should.eql([ 'one', 1, 'two', 1, 'one', 2, 'two', 2 ]); }) it('should add listeners for events which are same names with methods of Object.prototype', function(){ var emitter = new Emitter; var calls = []; emitter.on('constructor', function(val){ calls.push('one', val); }); emitter.on('__proto__', function(val){ calls.push('two', val); }); emitter.emit('constructor', 1); emitter.emit('__proto__', 2); calls.should.eql([ 'one', 1, 'two', 2 ]); }) }) describe('.once(event, fn)', function(){ it('should add a single-shot listener', function(){ var emitter = new Emitter; var calls = []; emitter.once('foo', function(val){ calls.push('one', val); }); emitter.emit('foo', 1); emitter.emit('foo', 2); emitter.emit('foo', 3); emitter.emit('bar', 1); calls.should.eql([ 'one', 1 ]); }) }) describe('.off(event, fn)', function(){ it('should remove a listener', function(){ var emitter = new Emitter; var calls = []; function one() { calls.push('one'); } function two() { calls.push('two'); } emitter.on('foo', one); emitter.on('foo', two); emitter.off('foo', two); emitter.emit('foo'); calls.should.eql([ 'one' ]); }) it('should work with .once()', function(){ var emitter = new Emitter; var calls = []; function one() { calls.push('one'); } emitter.once('foo', one); emitter.once('fee', one); emitter.off('foo', one); emitter.emit('foo'); calls.should.eql([]); }) it('should work when called from an event', function(){ var emitter = new Emitter , called function b () { called = true; } emitter.on('tobi', function () { emitter.off('tobi', b); }); emitter.on('tobi', b); emitter.emit('tobi'); called.should.be.true; called = false; emitter.emit('tobi'); called.should.be.false; }); }) describe('.off(event)', function(){ it('should remove all listeners for an event', function(){ var emitter = new Emitter; var calls = []; function one() { calls.push('one'); } function two() { calls.push('two'); } emitter.on('foo', one); emitter.on('foo', two); emitter.off('foo'); emitter.emit('foo'); emitter.emit('foo'); calls.should.eql([]); }) }) describe('.off()', function(){ it('should remove all listeners', function(){ var emitter = new Emitter; var calls = []; function one() { calls.push('one'); } function two() { calls.push('two'); } emitter.on('foo', one); emitter.on('bar', two); emitter.emit('foo'); emitter.emit('bar'); emitter.off(); emitter.emit('foo'); emitter.emit('bar'); calls.should.eql(['one', 'two']); }) }) describe('.listeners(event)', function(){ describe('when handlers are present', function(){ it('should return an array of callbacks', function(){ var emitter = new Emitter; function foo(){} emitter.on('foo', foo); emitter.listeners('foo').should.eql([foo]); }) }) describe('when no handlers are present', function(){ it('should return an empty array', function(){ var emitter = new Emitter; emitter.listeners('foo').should.eql([]); }) }) }) describe('.hasListeners(event)', function(){ describe('when handlers are present', function(){ it('should return true', function(){ var emitter = new Emitter; emitter.on('foo', function(){}); emitter.hasListeners('foo').should.be.true; }) }) describe('when no handlers are present', function(){ it('should return false', function(){ var emitter = new Emitter; emitter.hasListeners('foo').should.be.false; }) }) }) }) describe('Emitter(obj)', function(){ it('should mixin', function(done){ var proto = {}; Emitter(proto); proto.on('something', done); proto.emit('something'); }) })