diff options
author | Lance Stout <lancestout@gmail.com> | 2011-07-01 15:19:05 -0700 |
---|---|---|
committer | Lance Stout <lancestout@gmail.com> | 2011-07-01 15:19:05 -0700 |
commit | 7057984831b2a96980871476686273f8591f8101 (patch) | |
tree | 54c92d95ffb368570c041d48e45c68c1d3fe3e6d /sleekxmpp | |
parent | 774e0f2022f1ee318dc57c0008ea6cf1ddadce29 (diff) | |
parent | 2a2ac73845ffc8695e2bc55746f45e1a18d55e6c (diff) | |
download | slixmpp-7057984831b2a96980871476686273f8591f8101.tar.gz slixmpp-7057984831b2a96980871476686273f8591f8101.tar.bz2 slixmpp-7057984831b2a96980871476686273f8591f8101.tar.xz slixmpp-7057984831b2a96980871476686273f8591f8101.zip |
Merge branch 'develop' into roster
Diffstat (limited to 'sleekxmpp')
-rw-r--r-- | sleekxmpp/stanza/rootstanza.py | 5 | ||||
-rw-r--r-- | sleekxmpp/xmlstream/xmlstream.py | 29 |
2 files changed, 9 insertions, 25 deletions
diff --git a/sleekxmpp/stanza/rootstanza.py b/sleekxmpp/stanza/rootstanza.py index bc11476e..9e1d1cfa 100644 --- a/sleekxmpp/stanza/rootstanza.py +++ b/sleekxmpp/stanza/rootstanza.py @@ -64,8 +64,7 @@ class RootStanza(StanzaBase): # log the error log.exception('Error handling {%s}%s stanza' % (self.namespace, self.name)) - # Finally raise the exception, so it can be handled (or not) - # at a higher level by using sys.excepthook. - raise e + # Finally raise the exception to a global exception handler + self.stream.exception(e) register_stanza_plugin(RootStanza, Error) diff --git a/sleekxmpp/xmlstream/xmlstream.py b/sleekxmpp/xmlstream/xmlstream.py index 6282c8d0..c7d0d3a8 100644 --- a/sleekxmpp/xmlstream/xmlstream.py +++ b/sleekxmpp/xmlstream/xmlstream.py @@ -764,7 +764,6 @@ class XMLStream(object): Event handlers and the send queue will be threaded regardless of this parameter's value. """ - self._thread_excepthook() self.scheduler.process(threaded=True) def start_thread(name, target): @@ -1052,30 +1051,16 @@ class XMLStream(object): self.event_queue.put(('quit', None, None)) return - def _thread_excepthook(self): + def exception(self, exception): """ - If a threaded event handler raises an exception, there is no way to - catch it except with an excepthook. Currently, each thread has its own - excepthook, but ideally we could use the main sys.excepthook. + Process an unknown exception. - Modifies threading.Thread to use sys.excepthook when an exception - is not caught. - """ - init_old = threading.Thread.__init__ - - def init(self, *args, **kwargs): - init_old(self, *args, **kwargs) - run_old = self.run + Meant to be overridden. - def run_with_except_hook(*args, **kw): - try: - run_old(*args, **kw) - except (KeyboardInterrupt, SystemExit): - raise - except: - sys.excepthook(*sys.exc_info()) - self.run = run_with_except_hook - threading.Thread.__init__ = init + Arguments: + exception -- An unhandled exception object. + """ + pass # To comply with PEP8, method names now use underscores. |