fix #3186 (thanks dkirov)
This commit is contained in:
parent
24c8a3dcd1
commit
7dd8a27b39
|
@ -121,6 +121,7 @@ class P2PClient(IdleObject):
|
||||||
self.sock_type = TYPE_SERVER
|
self.sock_type = TYPE_SERVER
|
||||||
else:
|
else:
|
||||||
self.sock_type = TYPE_CLIENT
|
self.sock_type = TYPE_CLIENT
|
||||||
|
self.fd = -1
|
||||||
conn = P2PConnection('', _sock, host, port, self._caller, self.on_connect, self)
|
conn = P2PConnection('', _sock, host, port, self._caller, self.on_connect, self)
|
||||||
self.sock_hash = conn._sock.__hash__
|
self.sock_hash = conn._sock.__hash__
|
||||||
self.fd = conn.fd
|
self.fd = conn.fd
|
||||||
|
@ -129,6 +130,10 @@ class P2PClient(IdleObject):
|
||||||
for val in self.stanzaqueue:
|
for val in self.stanzaqueue:
|
||||||
stanza, is_message = val
|
stanza, is_message = val
|
||||||
if is_message:
|
if is_message:
|
||||||
|
if self.fd == -1:
|
||||||
|
self._caller.dispatch('MSGERROR',[unicode(self.to), -1, \
|
||||||
|
_('Connection to host could not be established'), None, None])
|
||||||
|
else:
|
||||||
if self.conn_holder.number_of_awaiting_messages.has_key(self.fd):
|
if self.conn_holder.number_of_awaiting_messages.has_key(self.fd):
|
||||||
self.conn_holder.number_of_awaiting_messages[self.fd]+=1
|
self.conn_holder.number_of_awaiting_messages[self.fd]+=1
|
||||||
else:
|
else:
|
||||||
|
@ -207,11 +212,11 @@ class P2PClient(IdleObject):
|
||||||
|
|
||||||
def on_disconnect(self):
|
def on_disconnect(self):
|
||||||
if self.conn_holder:
|
if self.conn_holder:
|
||||||
if self.conn_holder.number_of_awaiting_messages.has_key(self.fd):
|
if self.conn_holder.number_of_awaiting_messages.has_key(self.conn_holder.fd):
|
||||||
if self.conn_holder.number_of_awaiting_messages[self.fd] > 0:
|
if self.conn_holder.number_of_awaiting_messages[self.conn_holder.fd] > 0:
|
||||||
self._caller.dispatch('MSGERROR',[unicode(self.to), -1, \
|
self._caller.dispatch('MSGERROR',[unicode(self.to), -1, \
|
||||||
_('Connection to host could not be established'), None, None])
|
_('Connection to host could not be established'), None, None])
|
||||||
del self.conn_holder.number_of_awaiting_messages[self.fd]
|
del self.conn_holder.number_of_awaiting_messages[self.conn_holder.fd]
|
||||||
self.conn_holder.remove_connection(self.sock_hash)
|
self.conn_holder.remove_connection(self.sock_hash)
|
||||||
if self.__dict__.has_key('Dispatcher'):
|
if self.__dict__.has_key('Dispatcher'):
|
||||||
self.Dispatcher.PlugOut()
|
self.Dispatcher.PlugOut()
|
||||||
|
|
Loading…
Reference in New Issue