diff options
author | Kaz Kylheku <kaz@kylheku.com> | 2011-11-13 21:19:43 -0800 |
---|---|---|
committer | Kaz Kylheku <kaz@kylheku.com> | 2011-11-13 21:19:43 -0800 |
commit | 1232f5dbf8e68f9c3a7fe77360c0b950ecff3eac (patch) | |
tree | 18cb4ab7caf1d2b42139f98c80691e641a76efdd /unwind.c | |
parent | cc0f30f375914382e9e94e5bba26b14b2a734499 (diff) | |
download | txr-1232f5dbf8e68f9c3a7fe77360c0b950ecff3eac.tar.gz txr-1232f5dbf8e68f9c3a7fe77360c0b950ecff3eac.tar.bz2 txr-1232f5dbf8e68f9c3a7fe77360c0b950ecff3eac.zip |
Adding a debugger. This is an experimental prototype.
* Makefile (OBJS): New object file debug.o.
* dep.mk: Updated.
* match.c (h_fun): Use debug_begin and debug_end macros
to set up a debug frame for backtracing.
(match_line, match_files): Call debug_check to give debugger a chance
to instrument call.
(v_fun): Use debug_begin and debug_end macros to set up a debug frame
for backtracing. Call debug_check to give debugger a chance to
instrument call.
* stream.c (struct strm_ops): New function pointer, flush.
(stdio_maybe_write_error): Wrong word in error message corrected.
(stdio_flush): New static function.
(stdio_ops, pipe_ops): New function entered into tables.
(flush_stream): New function.
* stream.h (flush_stream): Declared.
* txr.c (help): New options documented.
(main): call to debug_init added. New debug options parsed and
opt_debugger set accordingly.
* unwind.c (uw_push_debug, uw_current_frame): New function.
* unwind.h (uw_frtype): New enumeration member UW_DBG.
(struct uw_debug): New frame variant.
(union uw_frame): New member, db.
(uw_push_debug, uw_current_frame): Declared,
* debug.c: New file.
* debug.h: New file.
Diffstat (limited to 'unwind.c')
-rw-r--r-- | unwind.c | 21 |
1 files changed, 21 insertions, 0 deletions
@@ -166,6 +166,22 @@ val uw_set_match_context(val context) return context; } +void uw_push_debug(uw_frame_t *fr, val func, val args, + val ub_p_a_pairs, val bindings, val data, + val line, val chr) +{ + fr->db.type = UW_DBG; + fr->db.func = func; + fr->db.args = args; + fr->db.ub_p_a_pairs = args; + fr->db.bindings = bindings; + fr->db.data = data; + fr->db.line = line; + fr->db.chr = chr; + fr->db.up = uw_stack; + uw_stack = fr; +} + void uw_pop_frame(uw_frame_t *fr) { assert (fr == uw_stack); @@ -176,6 +192,11 @@ void uw_pop_frame(uw_frame_t *fr) } } +uw_frame_t *uw_current_frame(void) +{ + return uw_stack; +} + val uw_block_return(val tag, val result) { uw_frame_t *ex; |