From 90af18f6884857704d72fd6b2bb91718aad72117 Mon Sep 17 00:00:00 2001 From: Eric Wong Date: Thu, 19 May 2011 23:54:59 -0700 Subject: epoll/xepoll: more consistent client implementations There's less logic in the server this way and easier to potentially share code this way. --- lib/rainbows/epoll/server.rb | 12 +++++++----- 1 file changed, 7 insertions(+), 5 deletions(-) (limited to 'lib/rainbows/epoll/server.rb') diff --git a/lib/rainbows/epoll/server.rb b/lib/rainbows/epoll/server.rb index 58e7653..ab5a49f 100644 --- a/lib/rainbows/epoll/server.rb +++ b/lib/rainbows/epoll/server.rb @@ -2,16 +2,14 @@ # :enddoc: module Rainbows::Epoll::Server @@nr = 0 - Rainbows::Epoll.nr_clients = lambda { @@nr } IN = SleepyPenguin::Epoll::IN | SleepyPenguin::Epoll::ET MAX = Rainbows.server.worker_connections THRESH = MAX - 1 LISTENERS = Rainbows::HttpServer::LISTENERS - EP = Rainbows::Epoll::EP + EP = Rainbows::EP - def self.run - LISTENERS.each { |sock| EP.add(sock.extend(self), IN) } - Rainbows::Epoll.loop + def self.nr + @@nr end # rearms all listeners when there's a free slot @@ -19,6 +17,10 @@ module Rainbows::Epoll::Server THRESH == (@@nr -= 1) and LISTENERS.each { |sock| EP.set(sock, IN) } end + def self.extended(sock) + EP.set(sock, IN) + end + def epoll_run return EP.delete(self) if @@nr >= MAX while io = kgio_tryaccept -- cgit v1.2.3-24-ge0c7