blob: 526ca26764700585982433fd9ee6c9ad761fba32 (
plain) (
tree)
|
|
module ActiveSupport
module Notifications
# This is a default queue implementation that ships with Notifications. It
# just pushes events to all registered log subscribers.
class Fanout
def initialize
@subscribers = []
@listeners_for = {}
end
def subscribe(pattern = nil, block = Proc.new)
@listeners_for.clear
Subscriber.new(pattern, block).tap do |s|
@subscribers << s
end
end
def unsubscribe(subscriber)
@listeners_for.clear
@subscribers.reject! {|s| s.matches?(subscriber)}
end
def publish(name, *args)
if listeners = @listeners_for[name]
listeners.each { |s| s.publish(name, *args) }
else
@listeners_for[name] = @subscribers.select { |s| s.publish(name, *args) }
end
end
# This is a sync queue, so there is not waiting.
def wait
end
class Subscriber #:nodoc:
def initialize(pattern, delegate)
@pattern = pattern
@delegate = delegate
end
def publish(message, *args)
return unless subscribed_to?(message)
@delegate.call(message, *args)
true
end
def subscribed_to?(name)
!@pattern || @pattern === name.to_s
end
def matches?(subscriber_or_name)
self === subscriber_or_name ||
@pattern && @pattern === subscriber_or_name
end
end
end
end
end
|