diff options
author | Matthew Wild <mwild1@gmail.com> | 2012-07-22 16:54:33 +0100 |
---|---|---|
committer | Matthew Wild <mwild1@gmail.com> | 2012-07-22 16:54:33 +0100 |
commit | 351865f51098e36eaa5e2de1f2ee603ce00db5e9 (patch) | |
tree | 10a190660d93f7b88592dc0e62a9c815706e8b09 /net/server_event.lua | |
parent | ccd9d1088cf92ec5e8291916848233a9e3609eba (diff) | |
download | prosody-351865f51098e36eaa5e2de1f2ee603ce00db5e9.tar.gz prosody-351865f51098e36eaa5e2de1f2ee603ce00db5e9.zip |
net.server_select, net.server_event: Change semantics of conn:close() - always call ondisconnect (with err == nil), and never close with data in send buffer (i.e. 'now' parameter removed)
Diffstat (limited to 'net/server_event.lua')
-rw-r--r-- | net/server_event.lua | 16 |
1 files changed, 8 insertions, 8 deletions
diff --git a/net/server_event.lua b/net/server_event.lua index 03a7708c..3c4185af 100644 --- a/net/server_event.lua +++ b/net/server_event.lua @@ -249,7 +249,7 @@ do return true end function interface_mt:_destroy() -- close this interface + events and call last listener - debug( "closing client with id:", self.id ) + debug( "closing client with id:", self.id, self.fatalerror ) self:_lock( true, true, true ) -- first of all, lock the interface to avoid further actions local _ _ = self.eventread and self.eventread:close( ) -- close events; this must be called outside of the event callbacks! @@ -328,22 +328,22 @@ do end return true end - function interface_mt:close(now) + function interface_mt:close() if self.nointerface then return nil, "locked"; end debug( "try to close client connection with id:", self.id ) if self.type == "client" then self.fatalerror = "client to close" - if ( not self.eventwrite ) or now then -- try to close immediately - self:_lock( true, true, true ) - self:_close() - return true - else -- wait for incomplete write request + if self.eventwrite then -- wait for incomplete write request self:_lock( true, true, false ) debug "closing delayed until writebuffer is empty" return nil, "writebuffer not empty, waiting" + else -- close now + self:_lock( true, true, true ) + self:_close() + return true end else - debug( "try to close server with id:", tostring(self.id), "args:", tostring(now) ) + debug( "try to close server with id:", tostring(self.id)) self.fatalerror = "server to close" self:_lock( true ) self:_close( 0 ) -- add new event to remove the server interface |