bottleneck
Version:
Distributed task scheduler and rate limiter
27 lines (25 loc) • 1.04 kB
text/coffeescript
class Events
constructor: () ->
= {}
.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.apply {}, args
if typeof ret?.then == "function"
ret.then(->).catch((e) => "error", [e])
catch e
if "name" != "error" then "error", [e]
module.exports = Events