Sha256: 954743fab8c552522183ad139e77be7119a8c97584d97b848fd3f074567cb470
Contents?: true
Size: 1.46 KB
Versions: 3
Compression:
Stored size: 1.46 KB
Contents
require 'thread' module Celluloid module IO # An alternative implementation of Celluloid::Mailbox using Wakers class Mailbox < Celluloid::Mailbox attr_reader :reactor, :waker def initialize @messages = [] @lock = Mutex.new @waker = Waker.new @reactor = Reactor.new(@waker) end # Add a message to the Mailbox def <<(message) @lock.synchronize do @messages << message @waker.signal end nil rescue DeadWakerError raise MailboxError, "dead recipient" end # Add a high-priority system event to the Mailbox def system_event(event) @lock.synchronize do @messages.unshift event begin @waker.signal rescue DeadWakerError # Silently fail if messages are sent to dead actors end end nil end # Receive a message from the Mailbox def receive(&block) message = nil begin @reactor.run_once do @waker.wait message = next_message(&block) end end until message message rescue IOError, DeadWakerError shutdown # force shutdown of the mailbox raise MailboxShutdown, "mailbox shutdown called during receive" end # Cleanup any IO objects this Mailbox may be using def shutdown @waker.cleanup super end end end end
Version data entries
3 entries across 3 versions & 1 rubygems
Version | Path |
---|---|
celluloid-0.6.2 | lib/celluloid/io/mailbox.rb |
celluloid-0.6.1 | lib/celluloid/io/mailbox.rb |
celluloid-0.6.0 | lib/celluloid/io/mailbox.rb |