Sha256: dfce7eb7783e34e92fdd6de89697605c1b18000a69b2d8c127beaeac6c2bb3c2

Contents?: true

Size: 1002 Bytes

Versions: 20

Compression:

Stored size: 1002 Bytes

Contents

module Concurrent
  module Actor
    module Behaviour

      # Links the actor to other actors and sends actor's events to them,
      # like: `:terminated`, `:paused`, errors, etc
      # TODO example
      class Linking < Abstract
        def initialize(core, subsequent)
          super core, subsequent
          @linked = Set.new
        end

        def on_envelope(envelope)
          case envelope.message
          when :link
            link envelope.sender
          when :unlink
            unlink envelope.sender
          when :linked?
            @linked.include? envelope.sender
          else
            pass envelope
          end
        end

        def link(ref)
          @linked.add(ref)
          true
        end

        def unlink(ref)
          @linked.delete(ref)
          true
        end

        def on_event(event)
          @linked.each { |a| a << event }
          @linked.clear if event == :terminated
          super event
        end
      end
    end
  end
end

Version data entries

20 entries across 20 versions & 1 rubygems

Version Path
concurrent-ruby-0.8.0 lib/concurrent/actor/behaviour/linking.rb
concurrent-ruby-0.8.0-java lib/concurrent/actor/behaviour/linking.rb
concurrent-ruby-0.7.2 lib/concurrent/actor/behaviour/linking.rb
concurrent-ruby-0.7.2-x86_64-linux lib/concurrent/actor/behaviour/linking.rb
concurrent-ruby-0.7.2-x86-solaris-2.11 lib/concurrent/actor/behaviour/linking.rb
concurrent-ruby-0.7.2-x86-mingw32 lib/concurrent/actor/behaviour/linking.rb
concurrent-ruby-0.7.2-x86-linux lib/concurrent/actor/behaviour/linking.rb
concurrent-ruby-0.7.2-x64-mingw32 lib/concurrent/actor/behaviour/linking.rb
concurrent-ruby-0.7.2-java lib/concurrent/actor/behaviour/linking.rb
concurrent-ruby-0.8.0.pre2 lib/concurrent/actor/behaviour/linking.rb
concurrent-ruby-0.8.0.pre2-java lib/concurrent/actor/behaviour/linking.rb
concurrent-ruby-0.8.0.pre1 lib/concurrent/actor/behaviour/linking.rb
concurrent-ruby-0.8.0.pre1-java lib/concurrent/actor/behaviour/linking.rb
concurrent-ruby-0.7.1 lib/concurrent/actor/behaviour/linking.rb
concurrent-ruby-0.7.1-x86_64-linux lib/concurrent/actor/behaviour/linking.rb
concurrent-ruby-0.7.1-x86-solaris-2.11 lib/concurrent/actor/behaviour/linking.rb
concurrent-ruby-0.7.1-x86-mingw32 lib/concurrent/actor/behaviour/linking.rb
concurrent-ruby-0.7.1-x86-linux lib/concurrent/actor/behaviour/linking.rb
concurrent-ruby-0.7.1-x64-mingw32 lib/concurrent/actor/behaviour/linking.rb
concurrent-ruby-0.7.1-java lib/concurrent/actor/behaviour/linking.rb