Socket: de-register setTimeout from supybot.drivers.poll's callbacks when dying.

This commit is contained in:
Valentin Lorentz 2020-05-29 19:42:42 +02:00
parent 88549f9faa
commit fabe8a284e

View File

@ -307,10 +307,8 @@ class SocketDriver(drivers.IrcDriver, drivers.ServersMixin):
'<http://docs.limnoria.net/en/latest/use/faq.html#how-to-make-a-connection-secure>') '<http://docs.limnoria.net/en/latest/use/faq.html#how-to-make-a-connection-secure>')
% self.irc.network) % self.irc.network)
def setTimeout(): conf.supybot.drivers.poll.addCallback(self.setTimeout)
self.conn.settimeout(conf.supybot.drivers.poll()) self.setTimeout()
conf.supybot.drivers.poll.addCallback(setTimeout)
setTimeout()
self.connected = True self.connected = True
self.resetDelay() self.resetDelay()
except socket.error as e: except socket.error as e:
@ -327,6 +325,9 @@ class SocketDriver(drivers.IrcDriver, drivers.ServersMixin):
return return
self._instances.append(self) self._instances.append(self)
def setTimeout():
self.conn.settimeout(conf.supybot.drivers.poll())
def _checkAndWriteOrReconnect(self): def _checkAndWriteOrReconnect(self):
self.writeCheckTime = None self.writeCheckTime = None
drivers.log.debug('Checking whether we are connected.') drivers.log.debug('Checking whether we are connected.')
@ -353,6 +354,7 @@ class SocketDriver(drivers.IrcDriver, drivers.ServersMixin):
def die(self): def die(self):
if self in self._instances: if self in self._instances:
self._instances.remove(self) self._instances.remove(self)
conf.supybot.drivers.poll.removeCallback(self.setTimeout)
self.zombie = True self.zombie = True
if self.nextReconnectTime is not None: if self.nextReconnectTime is not None:
self.nextReconnectTime = None self.nextReconnectTime = None