From 4a5fa0efdf5360b1e8cdee1c4ec868b843af2fa7 2012-11-02 21:26:28 From: DamianHeard Date: 2012-11-02 21:26:28 Subject: [PATCH] Fixed infinite loop on exit in the event of where multiple debuggers have been attached an there is an uncaught exception. I am in the process of submitting a similar patch for ipdb. --- diff --git a/IPython/core/debugger.py b/IPython/core/debugger.py index d733b30..85cd2ce 100644 --- a/IPython/core/debugger.py +++ b/IPython/core/debugger.py @@ -59,11 +59,11 @@ else: # Allow the set_trace code to operate outside of an ipython instance, even if # it does so with some limitations. The rest of this support is implemented in # the Tracer constructor. -def BdbQuit_excepthook(et,ev,tb): +def BdbQuit_excepthook(et,ev,tb,orig_hook): if et==bdb.BdbQuit: print('Exiting Debugger.') else: - BdbQuit_excepthook.excepthook_ori(et,ev,tb) + orig_hook(et,ev,tb) def BdbQuit_IPython_excepthook(self,et,ev,tb,tb_offset=None): print('Exiting Debugger.') @@ -108,8 +108,8 @@ class Tracer(object): ip = get_ipython() except NameError: # Outside of ipython, we set our own exception hook manually - BdbQuit_excepthook.excepthook_ori = sys.excepthook - sys.excepthook = BdbQuit_excepthook + sys.excepthook = lambda et, ev, tb, orig_hook=sys.excepthook: \ + BdbQuit_excepthook(et, ev, tb, orig_hook) def_colors = 'NoColor' try: # Limited tab completion support @@ -136,7 +136,7 @@ class Tracer(object): except: # This is only a user-facing convenience, so any error we encounter # here can be warned about but can be otherwise ignored. These - # printouts will tell us about problems if this API changes + # printouts will tell us about problems if this API changes import traceback traceback.print_exc() @@ -423,7 +423,7 @@ class Pdb(OldPdb): src = [] if filename == "" and hasattr(self, "_exec_filename"): filename = self._exec_filename - + for lineno in range(first, last+1): line = ulinecache.getline(filename, lineno) if not line: