方法
类公共方法
new() 链接
来源:显示 | 在 GitHub 上
# File actioncable/lib/action_cable/connection/stream_event_loop.rb, line 10 def initialize @nio = @executor = @thread = nil @map = {} @stopping = false @todo = Queue.new @spawn_mutex = Mutex.new end
实例公共方法
attach(io, stream) 链接
来源:显示 | 在 GitHub 上
# File actioncable/lib/action_cable/connection/stream_event_loop.rb, line 30 def attach(io, stream) @todo << lambda do @map[io] = @nio.register(io, :r) @map[io].value = stream end wakeup end
detach(io, stream) 链接
来源:显示 | 在 GitHub 上
# File actioncable/lib/action_cable/connection/stream_event_loop.rb, line 38 def detach(io, stream) @todo << lambda do @nio.deregister io @map.delete io io.close end wakeup end
post(task = nil, &block) 链接
来源:显示 | 在 GitHub 上
# File actioncable/lib/action_cable/connection/stream_event_loop.rb, line 23 def post(task = nil, &block) task ||= block spawn @executor << task end
stop() 链接
来源:显示 | 在 GitHub 上
# File actioncable/lib/action_cable/connection/stream_event_loop.rb, line 56 def stop @stopping = true wakeup if @nio end
timer(interval, &block) 链接
来源:显示 | 在 GitHub 上
# File actioncable/lib/action_cable/connection/stream_event_loop.rb, line 19 def timer(interval, &block) Concurrent::TimerTask.new(execution_interval: interval, &block).tap(&:execute) end
writes_pending(io) 链接
来源:显示 | 在 GitHub 上
# File actioncable/lib/action_cable/connection/stream_event_loop.rb, line 47 def writes_pending(io) @todo << lambda do if monitor = @map[io] monitor.interests = :rw end end wakeup end