From 22fa279b940b789ed594e12e6a327050f500ba75 2014-12-23 14:58:03 From: Thomas Kluyver Date: 2014-12-23 14:58:03 Subject: [PATCH] Restore support for Python < 2.7.9 See Python issue 21591 for details: http://bugs.python.org/issue21591 The combination of exec and a closure caused a problem on Python 2 older than 2.7.9. That was only released in December 2014, so we probably can't require it yet. --- diff --git a/IPython/core/interactiveshell.py b/IPython/core/interactiveshell.py index 0e5c8ca..e63785b 100644 --- a/IPython/core/interactiveshell.py +++ b/IPython/core/interactiveshell.py @@ -3029,11 +3029,6 @@ class InteractiveShell(SingletonConfigurable): # directly, so that the IPython crash handler doesn't get triggered old_excepthook, sys.excepthook = sys.excepthook, self.excepthook - # Convenience function to set result.error_in_exec - def set_result_exc(value=None): - if result is not None: - result.error_in_exec = value if (value is not None) else sys.exc_info()[1] - # we save the original sys.excepthook in the instance, in case config # code (such as magics) needs access to it. self.sys_excepthook = old_excepthook @@ -3047,15 +3042,18 @@ class InteractiveShell(SingletonConfigurable): # Reset our crash handler in place sys.excepthook = old_excepthook except SystemExit as e: - set_result_exc(e) + if result is not None: + result.error_in_exec = e self.showtraceback(exception_only=True) warn("To exit: use 'exit', 'quit', or Ctrl-D.", level=1) except self.custom_exceptions: etype, value, tb = sys.exc_info() - set_result_exc(value) + if result is not None: + result.error_in_exec = value self.CustomTB(etype, value, tb) except: - set_result_exc() + if result is not None: + result.error_in_exec = sys.exc_info()[1] self.showtraceback() else: outflag = 0