From a7104dc01c2319e9e909131b0f6a1bed31fc1205 Mon Sep 17 00:00:00 2001 From: James Lu Date: Tue, 5 Jan 2016 19:35:15 -0800 Subject: [PATCH 1/2] Revert "classes: actually, loop schedulePing only when connection_thread is alive" This reverts commit 124100fcf529dc0041676791b64aaf50cee12563. --- classes.py | 13 ++----------- 1 file changed, 2 insertions(+), 11 deletions(-) diff --git a/classes.py b/classes.py index 49bec0a..1dd6e96 100644 --- a/classes.py +++ b/classes.py @@ -398,23 +398,14 @@ class Irc(): def schedulePing(self): """Schedules periodic pings in a loop.""" - if not self.connection_thread: - # We're running in a non-threaded context, abort. - log.debug('(%s) Ignoring schedulePing() request since threading ' - 'seems to be disabled.', self.name) - return - - # Only run this loop for the duration where the listener thread - # is active! The goal is to stop the ping threads as soon as possible - # after the relevant listeners die. - while self.connection_thread.is_alive(): + while not self.aborted.is_set(): log.debug('(%s) Ping sent at %s', self.name, time.time()) self.proto.pingServer() # Sleep for the time (frequency) between pings. time.sleep(self.pingfreq) - log.debug('(%s) Canceling ping_thread at %s due to listener thread stopping.', self.name, time.time()) + log.debug('(%s) Canceling ping_thread at %s due to self.aborted being set.', self.name, time.time()) def spawnMain(self): """Spawns the main PyLink client.""" From a385bc32d9868a9de9ff1dc3e08dbcc07d784c29 Mon Sep 17 00:00:00 2001 From: James Lu Date: Tue, 5 Jan 2016 19:35:16 -0800 Subject: [PATCH 2/2] Revert "classes: replace threading.Timer with normal threads for schedulePing" This reverts commit 64bb646d1ec7bb67aa051e8acdab7e0def3a5c18. --- classes.py | 36 +++++++++++------------------------- 1 file changed, 11 insertions(+), 25 deletions(-) diff --git a/classes.py b/classes.py index 1dd6e96..6c6c7a9 100644 --- a/classes.py +++ b/classes.py @@ -56,9 +56,9 @@ class Irc(): # HACK: Don't thread if we're running tests. self.connect() else: - self.connection_thread = threading.Thread(target=self.connect, - name="Listener for %s" % self.name) + self.connection_thread = threading.Thread(target = self.connect) self.connection_thread.start() + self.pingTimer = None def initVars(self): """ @@ -128,8 +128,6 @@ class Irc(): self.uplink = None self.start_ts = int(time.time()) - self.ping_thread = None - def connect(self): """ Runs the connect loop for the IRC object. This is usually called by @@ -213,14 +211,8 @@ class Irc(): # and run the listen loop. self.proto.connect() self.spawnMain() - - # Spawn the ping loop as a separate thread. - log.info('(%s) Starting ping loop...', self.name) - self.ping_thread = threading.Thread(target=self.schedulePing, - name="Ping loop for %s" % self.name) - self.ping_thread.daemon = True - self.ping_thread.start() - + log.info('(%s) Starting ping schedulers....', self.name) + self.schedulePing() log.info('(%s) Server ready; listening for data.', self.name) self.run() else: # Configuration error :( @@ -288,12 +280,13 @@ class Irc(): def _disconnect(self): """Handle disconnects from the remote server.""" + log.debug('(%s) Canceling pingTimer at %s due to _disconnect() call', self.name, time.time()) self.connected.clear() try: self.socket.close() + self.pingTimer.cancel() except: # Socket timed out during creation; ignore pass - # Internal hook signifying that a network has disconnected. self.callHooks([None, 'PYLINK_DISCONNECT', {}]) @@ -397,15 +390,11 @@ class Irc(): def schedulePing(self): """Schedules periodic pings in a loop.""" - - while not self.aborted.is_set(): - log.debug('(%s) Ping sent at %s', self.name, time.time()) - self.proto.pingServer() - - # Sleep for the time (frequency) between pings. - time.sleep(self.pingfreq) - - log.debug('(%s) Canceling ping_thread at %s due to self.aborted being set.', self.name, time.time()) + self.proto.pingServer() + self.pingTimer = threading.Timer(self.pingfreq, self.schedulePing) + self.pingTimer.daemon = True + self.pingTimer.start() + log.debug('(%s) Ping scheduled at %s', self.name, time.time()) def spawnMain(self): """Spawns the main PyLink client.""" @@ -462,20 +451,17 @@ class IrcServer(): name: The name of the server. internal: Whether the server is an internal PyLink PseudoServer. """ - def __init__(self, uplink, name, internal=False, desc="(None given)"): self.uplink = uplink self.users = set() self.internal = internal self.name = name.lower() self.desc = desc - def __repr__(self): return repr(self.__dict__) class IrcChannel(): """PyLink IRC channel class.""" - def __init__(self): # Initialize variables, such as the topic, user list, TS, who's opped, etc. self.users = set()