Diff

net/server_epoll.lua @ 9506:ae6636052be9

net.server_epoll: Graceful handling of registering already added socket
author Kim Alvefur <zash@zash.se>
date Fri, 12 Oct 2018 03:20:09 +0200
parent 9499:36e379f058c8
child 9507:33d21f020b66
line wrap: on
line diff
--- a/net/server_epoll.lua	Sun Oct 14 14:32:02 2018 +0200
+++ b/net/server_epoll.lua	Fri Oct 12 03:20:09 2018 +0200
@@ -25,7 +25,10 @@
 local inet_pton = inet.pton;
 local _SOCKETINVALID = socket._SOCKETINVALID or -1;
 
-local poll = assert(require "util.poll".new());
+local poller = require "util.poll"
+local EEXIST = poller.EEXIST;
+
+local poll = assert(poller.new());
 
 local _ENV = nil;
 -- luacheck: std none
@@ -269,6 +272,10 @@
 	if w == nil then w = self._wantwrite; end
 	local ok, err, errno = poll:add(fd, r, w);
 	if not ok then
+		if errno == EEXIST then
+			log("debug", "%s already registered!", self);
+			return self:set(r, w); -- So try to change its flags
+		end
 		log("error", "Could not register %s: %s(%d)", self, err, errno);
 		return ok, err;
 	end