diff options
author | daurnimator <quae@daurnimator.com> | 2014-10-20 16:13:24 -0400 |
---|---|---|
committer | daurnimator <quae@daurnimator.com> | 2014-10-20 16:13:24 -0400 |
commit | dcd855afaa62797fc8285ff4a7a8e1a8f6279a1f (patch) | |
tree | 032ae646f40566f31102c4e76aacd8f843181945 /net/server_select.lua | |
parent | f0f0c0393ca2c0f6645fc2055c8e4aeffdac4225 (diff) | |
download | prosody-dcd855afaa62797fc8285ff4a7a8e1a8f6279a1f.tar.gz prosody-dcd855afaa62797fc8285ff4a7a8e1a8f6279a1f.zip |
Move timer code out of util.timer and into relevant net.server backends
Diffstat (limited to 'net/server_select.lua')
-rw-r--r-- | net/server_select.lua | 46 |
1 files changed, 46 insertions, 0 deletions
diff --git a/net/server_select.lua b/net/server_select.lua index 51449bdf..d8404001 100644 --- a/net/server_select.lua +++ b/net/server_select.lua @@ -42,6 +42,7 @@ local os_difftime = os.difftime local math_min = math.min local math_huge = math.huge local table_concat = table.concat +local table_insert = table.insert local string_sub = string.sub local coroutine_wrap = coroutine.wrap local coroutine_yield = coroutine.yield @@ -832,6 +833,50 @@ addtimer = function( listener ) return true end +local add_task do + local data = {}; + local new_data = {}; + + function add_task(delay, callback) + local current_time = luasocket_gettime(); + delay = delay + current_time; + if delay >= current_time then + table_insert(new_data, {delay, callback}); + else + local r = callback(current_time); + if r and type(r) == "number" then + return add_task(r, callback); + end + end + end + + addtimer(function() + local current_time = luasocket_gettime(); + if #new_data > 0 then + for _, d in pairs(new_data) do + table_insert(data, d); + end + new_data = {}; + end + + local next_time = math_huge; + for i, d in pairs(data) do + local t, callback = d[1], d[2]; + if t <= current_time then + data[i] = nil; + local r = callback(current_time); + if type(r) == "number" then + add_task(r, callback); + next_time = math_min(next_time, r); + end + else + next_time = math_min(next_time, t - current_time); + end + end + return next_time; + end); +end + stats = function( ) return _readtraffic, _sendtraffic, _readlistlen, _sendlistlen, _timerlistlen end @@ -1007,6 +1052,7 @@ end return { _addtimer = addtimer, + add_task = add_task; addclient = addclient, wrapclient = wrapclient, |