From bfdb003d454d3d8fb6385c2c758dab56ab622496 Mon Sep 17 00:00:00 2001 From: Mark Koch <48097969+mark-koch@users.noreply.github.com> Date: Thu, 25 Jul 2024 09:16:16 +0100 Subject: [PATCH] fix: Use correct hook for error printing inside jupyter notebooks (#324) Fixes #323 --- guppylang/error.py | 27 +++++++++++++++++++++++---- 1 file changed, 23 insertions(+), 4 deletions(-) diff --git a/guppylang/error.py b/guppylang/error.py index 17348d07..b0feebce 100644 --- a/guppylang/error.py +++ b/guppylang/error.py @@ -88,10 +88,29 @@ class InternalGuppyError(Exception): @contextmanager def exception_hook(hook: ExceptHook) -> Iterator[None]: """Sets a custom `excepthook` for the scope of a 'with' block.""" - old_hook = sys.excepthook - sys.excepthook = hook - yield - sys.excepthook = old_hook + try: + # Check if we're inside a jupyter notebook since it uses its own exception + # hook. If we're in a regular interpreter, this line will raise a `NameError` + ipython_shell = get_ipython() # type: ignore[name-defined] + + def ipython_excepthook( + shell: Any, + etype: type[BaseException], + value: BaseException, + tb: TracebackType | None, + tb_offset: Any = None, + ) -> Any: + return hook(etype, value, tb) + + ipython_shell.set_custom_exc((GuppyError,), ipython_excepthook) + yield + ipython_shell.set_custom_exc((), None) + except NameError: + # Otherwise, override the regular sys.excepthook + old_hook = sys.excepthook + sys.excepthook = hook + yield + sys.excepthook = old_hook def format_source_location(