aboutsummaryrefslogtreecommitdiffstats
path: root/net
diff options
context:
space:
mode:
authorMatthew Wild <mwild1@gmail.com>2013-12-16 23:31:43 +0000
committerMatthew Wild <mwild1@gmail.com>2013-12-16 23:31:43 +0000
commit341dfb3e52c741b4522727f264f9746ef6cde175 (patch)
tree00f37f6e7128e0cfa525566dc118d62f67fc38e6 /net
parenta4bf424187ea7e4649a7bc61415d0982e5b047cd (diff)
downloadprosody-341dfb3e52c741b4522727f264f9746ef6cde175.tar.gz
prosody-341dfb3e52c741b4522727f264f9746ef6cde175.zip
net.server_select: Don't remove the socket from sendlist when we might have data in the buffer (we'll now let sendbuffer() take care of that) (thanks daurnimator)
Diffstat (limited to 'net')
-rw-r--r--net/server_select.lua6
1 files changed, 1 insertions, 5 deletions
diff --git a/net/server_select.lua b/net/server_select.lua
index d0894715..22887265 100644
--- a/net/server_select.lua
+++ b/net/server_select.lua
@@ -916,13 +916,9 @@ local wrapclient = function( socket, ip, serverport, listeners, pattern, sslctx
-- When socket is writeable, call onconnect
local _sendbuffer = handler.sendbuffer;
handler.sendbuffer = function ()
- _sendlistlen = removesocket( _sendlist, socket, _sendlistlen );
handler.sendbuffer = _sendbuffer;
listeners.onconnect(handler);
- -- If there was data with the incoming packet, handle it now.
- if #handler:bufferqueue() > 0 then
- return _sendbuffer();
- end
+ return _sendbuffer(); -- Send any queued outgoing data
end
end
end