diff options
author | Eric Wong <normalperson@yhbt.net> | 2009-10-25 16:34:33 -0700 |
---|---|---|
committer | Eric Wong <normalperson@yhbt.net> | 2009-10-26 02:26:22 -0700 |
commit | fa93a16ede574df6159497a526153a9978b66dd1 (patch) | |
tree | 7df4902849493bdf7a5547153e4c5934cbef9b13 /lib/rainbows/event_machine.rb | |
parent | 8487d928f9581d98aee14e1991f129422278367c (diff) | |
download | rainbows-fa93a16ede574df6159497a526153a9978b66dd1.tar.gz |
log reopens, graceful shutdown, HTTP error responses should all be working now.
Diffstat (limited to 'lib/rainbows/event_machine.rb')
-rw-r--r-- | lib/rainbows/event_machine.rb | 22 |
1 files changed, 19 insertions, 3 deletions
diff --git a/lib/rainbows/event_machine.rb b/lib/rainbows/event_machine.rb index 2cc0f15..176bf51 100644 --- a/lib/rainbows/event_machine.rb +++ b/lib/rainbows/event_machine.rb @@ -37,6 +37,11 @@ module Rainbows alias write send_data alias receive_data on_read + def quit + super + close_connection_after_writing + end + def app_call begin (@env[RACK_INPUT] = @input).rewind @@ -54,7 +59,7 @@ module Rainbows # keepalive requests are always body-less, so @input is unchanged @hp.headers(@env, @buf) and next else - @state = :close + quit end return end while true @@ -89,6 +94,11 @@ module Rainbows @em_conns = conns end + def close + detach + @l.close + end + def notify_readable return if @em_conns.size >= @limit begin @@ -109,8 +119,14 @@ module Rainbows EM.run { conns = EM.instance_variable_get(:@conns) or raise RuntimeError, "EM @conns instance variable not accessible!" - EM.add_periodic_timer(1) { worker.tmp.chmod(m = 0 == m ? 1 : 0) } - LISTENERS.each { |s| EM.attach(s, Server, s, conns) } + EM.add_periodic_timer(1) do + worker.tmp.chmod(m = 0 == m ? 1 : 0) + unless G.alive + conns.each_value { |client| Client === client and client.quit } + EM.stop if conns.empty? && EM.reactor_running? + end + end + LISTENERS.map! { |s| EM.attach(s, Server, s, conns) } } end |