Sha256: 3c701437b4623ca57f6ca62b2dfed04465e7456b1f56096a8faec1ed7a11d0c1
Contents?: true
Size: 1.47 KB
Versions: 5
Compression:
Stored size: 1.47 KB
Contents
require 'set' module Celluloid # Allow methods to directly interact with the actor protocol class Receivers def initialize @receivers = Set.new @timers = Timers.new end # Receive an asynchronous message def receive(timeout = nil, &block) if Celluloid.exclusive? Thread.mailbox.receive(timeout, &block) else receiver = Receiver.new block if timeout receiver.timer = @timers.add(timeout) do @receivers.delete receiver receiver.resume end end @receivers << receiver Task.suspend :receiving end end # How long to wait until the next timer fires def wait_interval @timers.wait_interval end # Fire any pending timers def fire_timers @timers.fire end # Handle incoming messages def handle_message(message) receiver = @receivers.find { |r| r.match(message) } return unless receiver @receivers.delete receiver @timers.cancel receiver.timer if receiver.timer receiver.resume message end end # Methods blocking on a call to receive class Receiver attr_accessor :timer def initialize(block) @block = block @task = Task.current @timer = nil end # Match a message with this receiver's block def match(message) @block ? @block.call(message) : true end def resume(message = nil) @task.resume message end end end
Version data entries
5 entries across 5 versions & 2 rubygems