From 74b4ea20bf369aec8196fd65cc80e717198a37bb Mon Sep 17 00:00:00 2001 From: mathieui Date: Mon, 23 Feb 2015 17:43:35 +0100 Subject: Add back stanza-specific exception handlers (fixes the test suite too) --- slixmpp/xmlstream/xmlstream.py | 11 +++++++++-- 1 file changed, 9 insertions(+), 2 deletions(-) (limited to 'slixmpp/xmlstream') diff --git a/slixmpp/xmlstream/xmlstream.py b/slixmpp/xmlstream/xmlstream.py index 959169d1..aec89c7f 100644 --- a/slixmpp/xmlstream/xmlstream.py +++ b/slixmpp/xmlstream/xmlstream.py @@ -706,6 +706,7 @@ class XMLStream(asyncio.BaseProtocol): handlers = self.__event_handlers.get(name, []) for handler in handlers: handler_callback, disposable = handler + old_exception = getattr(data, 'exception', None) # If the callback is a coroutine, schedule it instead of # running it directly @@ -715,13 +716,19 @@ class XMLStream(asyncio.BaseProtocol): try: yield from cb(data) except Exception as e: - self.exception(e) + if old_exception: + old_exception(e) + else: + self.exception(e) asyncio.async(handler_callback_routine(handler_callback)) else: try: handler_callback(data) except Exception as e: - self.exception(e) + if old_exception: + old_exception(e) + else: + self.exception(e) if disposable: # If the handler is disposable, we will go ahead and # remove it now instead of waiting for it to be -- cgit v1.2.3