diff options
author | Eric Wong <normalperson@yhbt.net> | 2010-12-27 13:10:57 -0800 |
---|---|---|
committer | Eric Wong <normalperson@yhbt.net> | 2010-12-27 21:11:31 +0000 |
commit | 728496a31f34234b46d7025a23933aa06dd824f5 (patch) | |
tree | 3853385379df54b0f1d2d3927e2fa5817cbe2bf2 /lib/rainbows/fiber/rev/heartbeat.rb | |
parent | 0766c1eb631190ee514a90e4d20a941f0a310054 (diff) | |
download | rainbows-728496a31f34234b46d7025a23933aa06dd824f5.tar.gz |
Blindly resuming fibers every second is a waste of cycles, we can use the ZZ hash in regular FiberSpawn to resume expired fibers on an as-needed basis. While we're at it, merge the keepalive-timeout class into the heartbeat, there's no reason to have separate timers and classes here.
Diffstat (limited to 'lib/rainbows/fiber/rev/heartbeat.rb')
-rw-r--r-- | lib/rainbows/fiber/rev/heartbeat.rb | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/lib/rainbows/fiber/rev/heartbeat.rb b/lib/rainbows/fiber/rev/heartbeat.rb index 9411b4a..f9ef573 100644 --- a/lib/rainbows/fiber/rev/heartbeat.rb +++ b/lib/rainbows/fiber/rev/heartbeat.rb @@ -2,7 +2,14 @@ # :enddoc: class Rainbows::Fiber::Rev::Heartbeat < Rev::TimerWatcher G = Rainbows::G + + # ZZ gets populated by read_expire in rainbows/fiber/io/methods + ZZ = Rainbows::Fiber::ZZ def on_timer exit if (! G.tick && G.cur <= 0) + now = Time.now + fibs = [] + ZZ.delete_if { |fib, time| now >= time ? fibs << fib : ! fib.alive? } + fibs.each { |fib| fib.resume if fib.alive? } end end |