Class: Concurrent::Actor::Root

Inherits:
AbstractContext show all
Defined in:
lib/concurrent/actor/root.rb

Overview

implements the root actor

Instance Attribute Summary

Attributes inherited from AbstractContext

#core

Instance Method Summary collapse

Methods inherited from AbstractContext

#ask, #default_executor, #default_reference_class, #envelope, #on_envelope, #on_event, #pass, spawn, spawn!, #tell

Methods included from InternalDelegations

#behaviour, #behaviour!, #children, #context, #log, #redirect, #terminate!, #terminated?

Methods included from PublicDelegations

#context_class, #executor, #name, #parent, #path, #reference

Methods included from TypeCheck

#Child!, #Child?, #Match!, #Match?, #Type!, #Type?

Constructor Details

#initializeRoot

Returns a new instance of Root.



6
7
8
9
10
11
12
# File 'lib/concurrent/actor/root.rb', line 6

def initialize
  # noinspection RubyArgCount
  @dead_letter_router = Core.new(parent:    reference,
                                 class:     DefaultDeadLetterHandler,
                                 supervise: true,
                                 name:      :default_dead_letter_handler).reference
end

Instance Method Details

#behaviour_definitionObject



30
31
32
33
34
# File 'lib/concurrent/actor/root.rb', line 30

def behaviour_definition
  [*Behaviour.base(:just_log),
   *Behaviour.supervising,
   *Behaviour.user_messages]
end

#dead_letter_routingObject



26
27
28
# File 'lib/concurrent/actor/root.rb', line 26

def dead_letter_routing
  @dead_letter_router
end

#on_message(message) ⇒ Object

to allow spawning of new actors, spawn needs to be called inside the parent Actor



15
16
17
18
19
20
21
22
23
24
# File 'lib/concurrent/actor/root.rb', line 15

def on_message(message)
  case
  when message.is_a?(::Array) && message.first == :spawn
    Actor.spawn message[1], &message[2]
  when message == :dead_letter_routing
    @dead_letter_router
  else
    # ignore
  end
end