mirror of
https://github.com/jlu5/PyLink.git
synced 2025-01-12 05:02:33 +01:00
Irc: fix throttle_time not actually blocking for the defined amount of time
Passing the timeout to queue.Queue.get is invalid because it'll only block if there ISN'T any text to send.
This commit is contained in:
parent
ce77f2cbd4
commit
62aea23879
12
classes.py
12
classes.py
@ -176,11 +176,15 @@ class Irc(utils.DeprecatedAttributesObject):
|
||||
|
||||
def processQueue(self):
|
||||
"""Loop to process outgoing queue data."""
|
||||
while not self.aborted.is_set():
|
||||
while True:
|
||||
throttle_time = self.serverdata.get('throttle_time', 0.005)
|
||||
data = self.queue.get(throttle_time)
|
||||
if data:
|
||||
self._send(data)
|
||||
if not self.aborted.wait(throttle_time):
|
||||
try:
|
||||
data = self.queue.get_nowait()
|
||||
self._send(data)
|
||||
except Queue.Empty:
|
||||
pass
|
||||
|
||||
log.debug('(%s) Stopping queue thread as aborted is set', self.name)
|
||||
|
||||
def connect(self):
|
||||
|
Loading…
Reference in New Issue
Block a user