Class: Concurrent::Actor::Utils::Broadcast
Relationships & Source Files | |
Super Chains via Extension / Inclusion / Inheritance | |
Class Chain:
|
|
Instance Chain:
|
|
Inherits: |
Concurrent::Actor::RestartingContext
|
Defined in: | lib/concurrent-ruby-edge/concurrent/actor/utils/broadcast.rb |
Overview
Allows to build pub/sub easily.
Constant Summary
Concern::Logging
- Included
Class Method Summary
- .new ⇒ Broadcast constructor
Actor::AbstractContext
- Inherited
.spawn | Behaves as Concurrent::Actor.spawn but |
.spawn! | behaves as Concurrent::Actor.spawn! but |
.to_spawn_options |
Instance Attribute Summary
Instance Method Summary
-
#filtered_receivers
override to define different behaviour, filtering etc.
- #on_message(message)
Actor::RestartingContext
- Inherited
Actor::AbstractContext
- Inherited
#<< | Alias for AbstractContext#tell. |
#ask, | |
#ask! | Alias for AbstractContext#ask. |
#behaviour_definition, | |
#dead_letter_routing | Defines an actor responsible for dead letters. |
#default_executor | override to se different default executor, e.g. |
#default_reference_class | override if different class for reference is needed. |
#envelope, | |
#on_event | override to add custom code invocation on internal events like |
#on_message, | |
#pass | if you want to pass the message to next behaviour, usually |
#tell | tell self a message. |
#initialize_core, #on_envelope |
Actor::InternalDelegations
- Included
#behaviour | see Core#behaviour |
#behaviour! | see Core#behaviour! |
#children, #context, #dead_letter_routing, | |
#log | delegates to core.log. |
#redirect, #terminate! |
Concern::Logging
- Included
#log | Logs through Concurrent.global_logger, it can be overridden by setting @logger. |
Actor::PublicDelegations
- Included
#actor_class | Alias for PublicDelegations#context_class. |
#context_class, #executor, #name, #parent, #path, | |
#ref | Alias for PublicDelegations#reference. |
#reference |
Actor::TypeCheck
- Included
Constructor Details
.new ⇒ Broadcast
# File 'lib/concurrent-ruby-edge/concurrent/actor/utils/broadcast.rb', line 23
def initialize @receivers = Set.new end
Instance Method Details
#filtered_receivers
override to define different behaviour, filtering etc
# File 'lib/concurrent-ruby-edge/concurrent/actor/utils/broadcast.rb', line 46
def filtered_receivers @receivers end
#on_message(message)
[ GitHub ]# File 'lib/concurrent-ruby-edge/concurrent/actor/utils/broadcast.rb', line 27
def ( ) case when :subscribe if envelope.sender.is_a? Reference @receivers.add envelope.sender true else false end when :unsubscribe !!@receivers.delete(envelope.sender) when :subscribed? @receivers.include? envelope.sender else filtered_receivers.each { |r| r << } end end