![]() System : Linux absol.cf 5.4.0-198-generic #218-Ubuntu SMP Fri Sep 27 20:18:53 UTC 2024 x86_64 User : www-data ( 33) PHP Version : 7.4.33 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare, Directory : /var/lib/gems/2.5.0/gems/em-synchrony-1.0.3/examples/go/ |
Upload File : |
require 'em-synchrony' module Kernel def go(*args, &blk) EM.next_tick do Fiber.new { blk.call(*args) }.resume end end end class Channel < EM::Queue def initialize(opts = {}) @limit = opts[:size] @prodq = [] @size = 0 super() end def size; @size; end def empty?; size == 0; end def pop f = Fiber.current clb = Proc.new do |*args| @size -= 1 f.resume(args) @prodq.shift.call if !@prodq.empty? end super(&clb) Fiber.yield end def push(*items) f = Fiber.current @size += 1 EM.next_tick { super(*items) } # if the queue is bounded, then suspend the producer # until someone consumes a pending message if @limit && size >= @limit @prodq.push -> { f.resume } Fiber.yield end end alias :<< :push end