X-Git-Url: https://wannabe.guru.org/gitweb/?a=blobdiff_plain;f=bootstrap.py;h=1fcdec3de7f223230910bb24797a1bd68ca10134;hb=723f5fcb660eef79cc455cfb3f2eebfa667c90fa;hp=a4923b4a9ce3424b80475c801dde8f93ed49b48f;hpb=b69d402dc503a0d38381bfa0fcd6dd5829e92775;p=python_utils.git diff --git a/bootstrap.py b/bootstrap.py index a4923b4..1fcdec3 100644 --- a/bootstrap.py +++ b/bootstrap.py @@ -93,24 +93,24 @@ def handle_uncaught_exception(exc_type, exc_value, exc_tb): sys.__excepthook__(exc_type, exc_value, exc_tb) return else: + import io + import traceback + + tb_output = io.StringIO() + traceback.print_tb(exc_tb, None, tb_output) + print(tb_output.getvalue(), file=sys.stderr) + logger.error(tb_output.getvalue()) + tb_output.close() + + # stdin or stderr is redirected, just do the normal thing if not sys.stderr.isatty() or not sys.stdin.isatty(): - # stdin or stderr is redirected, just do the normal thing ORIGINAL_EXCEPTION_HOOK(exc_type, exc_value, exc_tb) - else: - # a terminal is attached and stderr is not redirected, maybe debug. - import io - import traceback - - tb_output = io.StringIO() - traceback.print_tb(exc_tb, None, tb_output) - print(tb_output.getvalue(), file=sys.stderr) - logger.error(tb_output.getvalue()) - tb_output.close() + else: # a terminal is attached and stderr isn't redirected, maybe debug. if config.config['debug_unhandled_exceptions']: + logger.info("Invoking the debugger...") import pdb - logger.info("Invoking the debugger...") pdb.pm() else: ORIGINAL_EXCEPTION_HOOK(exc_type, exc_value, exc_tb)