diff options
author | Michael Snyder <msnyder@vmware.com> | 1998-01-02 17:09:12 +0000 |
---|---|---|
committer | Michael Snyder <msnyder@vmware.com> | 1998-01-02 17:09:12 +0000 |
commit | 99fa2de001f04c4fb2a21d24b71452e8ec69f823 (patch) | |
tree | cae7581b7dd174d2e4c18ca39c84d988c33dd65a /gdb | |
parent | 43b043cf656c0648df67b709f7cd72028c6804bb (diff) | |
download | binutils-99fa2de001f04c4fb2a21d24b71452e8ec69f823.zip binutils-99fa2de001f04c4fb2a21d24b71452e8ec69f823.tar.gz binutils-99fa2de001f04c4fb2a21d24b71452e8ec69f823.tar.bz2 |
Fri Jan 2 17:06:05 1998 Michael Snyder (msnyder@cleaver.cygnus.com)
* tracepoint.c (finish_tfind_command): improved algorithm for
deciding when we've "stepped" into a new stack frame.
(map_args_over_tracepoints): loop over tracepoint list "safely",
since list elements may be deleted during loop.
(read_actions): add actions to history list.
Diffstat (limited to 'gdb')
-rw-r--r-- | gdb/ChangeLog | 8 | ||||
-rw-r--r-- | gdb/tracepoint.c | 26 |
2 files changed, 29 insertions, 5 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog index face205..f0d0be7 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,11 @@ +Fri Jan 2 17:06:05 1998 Michael Snyder (msnyder@cleaver.cygnus.com) + + * tracepoint.c (finish_tfind_command): improved algorithm for + deciding when we've "stepped" into a new stack frame. + (map_args_over_tracepoints): loop over tracepoint list "safely", + since list elements may be deleted during loop. + (read_actions): add actions to history list. + Fri Jan 2 16:56:16 1998 Michael Snyder (msnyder@cleaver.cygnus.com) [From Keith Seitz (kseitz@cygnus.com)] diff --git a/gdb/tracepoint.c b/gdb/tracepoint.c index f2c5160..11e83d9 100644 --- a/gdb/tracepoint.c +++ b/gdb/tracepoint.c @@ -617,12 +617,12 @@ map_args_over_tracepoints (args, from_tty, opcode) int from_tty; enum tracepoint_opcode opcode; { - struct tracepoint *t; + struct tracepoint *t, *tmp; int tpnum; char *cp; if (args == 0 || *args == 0) /* do them all */ - ALL_TRACEPOINTS (t) + ALL_TRACEPOINTS_SAFE (t, tmp) tracepoint_operation (t, from_tty, opcode); else while (*args) @@ -830,7 +830,11 @@ read_actions (t) if (readline_hook && instream == NULL) line = (*readline_hook) (prompt); else if (instream == stdin && ISATTY (instream)) - line = readline (prompt); + { + line = readline (prompt); + if (line && *line) /* add it to command history */ + add_history (line); + } else line = gdb_readline (0); @@ -1708,8 +1712,20 @@ finish_tfind_command (msg, from_tty) { int source_only; - if (old_frame_addr == FRAME_FP (get_current_frame ()) && - old_func == find_pc_function (read_pc ())) + /* NOTE: in immitation of the step command, try to determine + whether we have made a transition from one function to another. + If so, we'll print the "stack frame" (ie. the new function and + it's arguments) -- otherwise we'll just show the new source line. + + This determination is made by checking (1) whether the current + function has changed, and (2) whether the current FP has changed. + Hack: if the FP wasn't collected, either at the current or the + previous frame, assume that the FP has NOT changed. */ + + if (old_func == find_pc_function (read_pc ()) && + (old_frame_addr == 0 || + FRAME_FP (get_current_frame ()) == 0 || + old_frame_addr == FRAME_FP (get_current_frame ()))) source_only = -1; else source_only = 1; |