diff options
author | Kaz Kylheku <kaz@kylheku.com> | 2018-03-12 06:26:39 -0700 |
---|---|---|
committer | Kaz Kylheku <kaz@kylheku.com> | 2018-03-12 06:26:39 -0700 |
commit | 656a8eaea985f569376871a479ee1abf4d99d82e (patch) | |
tree | 3bcadd6339163745c3046ddec8e39c84c9d60597 /unwind.c | |
parent | 0ed1a4855cd4c821107dde0eb43e472fe233374b (diff) | |
download | txr-656a8eaea985f569376871a479ee1abf4d99d82e.tar.gz txr-656a8eaea985f569376871a479ee1abf4d99d82e.tar.bz2 txr-656a8eaea985f569376871a479ee1abf4d99d82e.zip |
unwind: better debugging of exceptions.
Once upon a time when we didn't have continuable warning
exceptions, it was easy to debug internal error throws in TXR:
just set a breakpoint on uw_throw and catch it in the
debugger. This approach became unworkable with uw_throw being
executed numerous times as part of the ordinary program
control flow. With this change, we get that debugging
experience back.
* unwind.c (uw_break_on_error): New static variable.
(uw_throw): If the break-on-error variable is set and we
are processing an exception derived from error, then
call the breakpt function.
Diffstat (limited to 'unwind.c')
-rw-r--r-- | unwind.c | 9 |
1 files changed, 9 insertions, 0 deletions
@@ -65,6 +65,10 @@ static val frame_type, catch_frame_type, handle_frame_type; static val deferred_warnings, tentative_defs; +#if CONFIG_EXTRA_DEBUGGING +static int uw_break_on_error; +#endif + /* C99 inline instantiations. */ #if __STDC_VERSION__ >= 199901L val uw_block_return(val tag, val result); @@ -555,6 +559,11 @@ val uw_throw(val sym, val args) abort(); } +#if CONFIG_EXTRA_DEBUGGING + if (uw_break_on_error && uw_exception_subtype_p(sym, error_s)) + breakpt(); +#endif + if (!listp(args)) args = cons(args, nil); |