Software /
code /
prosody
Diff
net/server_epoll.lua @ 7573:0f0a6febbc5a
net.server_epoll: Add some comments
author | Kim Alvefur <zash@zash.se> |
---|---|
date | Thu, 18 Aug 2016 01:52:18 +0200 |
parent | 7564:f95ffd24e042 |
child | 7574:97b8506118a9 |
line wrap: on
line diff
--- a/net/server_epoll.lua Tue Aug 16 14:53:29 2016 +0200 +++ b/net/server_epoll.lua Thu Aug 18 01:52:18 2016 +0200 @@ -40,17 +40,24 @@ t[2] = noop; end +-- Set to true when timers have changed local resort_timers = false; + +-- Add absolute timer local function at(time, f) local timer = { time, f, close = closetimer }; t_insert(timers, timer); resort_timers = true; return timer; end + +-- Add relative timer local function addtimer(timeout, f) return at(gettime() + timeout, f); end +-- Run callbacks of expired timers +-- Return time until next timeout local function runtimers() if resort_timers then -- Sort earliest timers to the end @@ -76,6 +83,7 @@ local t, f = timer[1], timer[2]; local now = gettime(); -- inside or before the loop? if t > now then + -- This timer should not fire yet local diff = t - now; if diff < next_delay then next_delay = diff; @@ -92,7 +100,7 @@ end if resort_timers or next_delay < 1e-6 then -- Timers may be added from within a timer callback. - -- Those would not be considered for next_dela, + -- Those would not be considered for next_delay, -- and we might sleep for too long, so instead -- we return a shorter timeout so we can -- properly sort all new timers. @@ -222,6 +230,7 @@ return true; end +-- Called when socket is readable function interface:onreadable() local data, err, partial = self.conn:receive(self._pattern); if data or partial then @@ -242,6 +251,7 @@ end end +-- Called when socket is writable function interface:onwriteable() local buffer = self.writebuffer; local data = t_concat(buffer);