SleekXMPP/sleekxmpp/xmlstream/handler/waiter.py

28 lines
609 B
Python
Raw Normal View History

2009-06-03 22:56:51 +00:00
from . import base
import queue
2009-06-03 22:56:51 +00:00
import logging
class Waiter(base.BaseHandler):
def __init__(self, name, matcher):
base.BaseHandler.__init__(self, name, matcher)
self._payload = queue.Queue()
2009-06-03 22:56:51 +00:00
def prerun(self, payload):
2009-10-19 05:27:00 +00:00
logging.debug("Putting into Waiter %s" % self.name)
2009-06-03 22:56:51 +00:00
self._payload.put(payload)
def run(self, payload):
pass
2009-06-03 22:56:51 +00:00
def wait(self, timeout=60):
2009-10-19 05:27:00 +00:00
logging.debug("Waiting on %s." % self.name)
2009-06-03 22:56:51 +00:00
try:
return self._payload.get(True, timeout)
except queue.Empty:
2009-10-19 05:27:00 +00:00
logging.warning("Timed out waiting for %s" % self.name)
2009-06-03 22:56:51 +00:00
return False
def checkDelete(self):
return True