Sha256: 51e15ab79a0801e655b6fd5c5a3c874816a8837b1c3d56bdcf33d561fb957122
Contents?: true
Size: 1.51 KB
Versions: 1
Compression:
Stored size: 1.51 KB
Contents
require 'set' require 'timers' module Celluloid # Allow methods to directly interact with the actor protocol class Receivers def initialize @receivers = Set.new @timers = Timers::Group.new end # Receive an asynchronous message def receive(timeout = nil, &block) if Celluloid.exclusive? Celluloid.mailbox.receive(timeout, &block) else receiver = Receiver.new block if timeout receiver.timer = @timers.after(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 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
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
celluloid-0.16.0.pre2 | lib/celluloid/receivers.rb |