bottleneck
Version:
Distributed task scheduler and rate limiter
28 lines (26 loc) • 1.13 kB
text/coffeescript
class Events
constructor: () ->
= {}
if .on? or .once? or .removeAllListeners?
throw new Error "An Emitter already exists for this object"
.on = (name, cb) => name, "many", cb
.once = (name, cb) => name, "once", cb
.removeAllListeners = (name=null) =>
if name? then delete [name] else = {}
_addListener: (name, status, cb) ->
[name] ?= []
[name].push {cb, status}
trigger: (name, args...) ->
if name != "debug" then "debug", "Event triggered: #{name}", args
return unless [name]?
[name] = [name].filter (listener) -> listener.status != "none"
[name].forEach (listener) =>
return if listener.status == "none"
if listener.status == "once" then listener.status = "none"
try
ret = listener.cb?(args...)
ret?.then?(->).catch((e) => "error", e)
catch e
if "name" != "error" then "error", e
module.exports = Events