UNPKG

@railzai/bottleneck

Version:

Distributed task scheduler and rate limiter

29 lines (18 loc) 765 B
DLList = require "./DLList" Events = require "./Events" class Queues constructor: (num_priorities) -> @Events = new Events @ @_length = 0 @_lists = for i in [1..num_priorities] then new DLList (=> @incr()), (=> @decr()) incr: -> if @_length++ == 0 then @Events.trigger "leftzero" decr: -> if --@_length == 0 then @Events.trigger "zero" push: (job) -> @_lists[job.options.priority].push job queued: (priority) -> if priority? then @_lists[priority].length else @_length shiftAll: (fn) -> @_lists.forEach (list) -> list.forEachShift fn getFirst: (arr=@_lists) -> for list in arr return list if list.length > 0 [] shiftLastFrom: (priority) -> @getFirst(@_lists[priority..].reverse()).shift() module.exports = Queues