diff options
author | Michael Snyder <msnyder@specifix.com> | 2008-06-26 00:23:57 +0000 |
---|---|---|
committer | Michael Snyder <msnyder@specifix.com> | 2008-06-26 00:23:57 +0000 |
commit | 9bd07601d619fcf4957d3489ece6d8ba2737ae1e (patch) | |
tree | e6d9465ad7c09c7632c43df5f035391f8f962b84 /gdb/gdbserver/gdbfreeplay-back.c | |
parent | a9d88e0e9123304ed7b3549a33dd044625c4be19 (diff) | |
download | gdb-9bd07601d619fcf4957d3489ece6d8ba2737ae1e.tar.gz |
2008-06-25 Michael Snyder <msnyder@specifix.com>msnyder-reverse-20080609-branchcvs/msnyder-reverse-20080609-branch
* gdbfreeplay-back.c (frame_find_request): Rewrite loop to
avoid fencepost error on last frame.
Diffstat (limited to 'gdb/gdbserver/gdbfreeplay-back.c')
-rw-r--r-- | gdb/gdbserver/gdbfreeplay-back.c | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/gdb/gdbserver/gdbfreeplay-back.c b/gdb/gdbserver/gdbfreeplay-back.c index bcfe49bfc17..7d7cf415beb 100644 --- a/gdb/gdbserver/gdbfreeplay-back.c +++ b/gdb/gdbserver/gdbfreeplay-back.c @@ -326,11 +326,12 @@ frame_find_request (FILE *logfile, char *request) curpos = stopframe[cur_frame].eventpos; fseek (logfile, curpos, SEEK_SET); /* Now search for a matching request. */ - while (curpos < stopframe[cur_frame + 1].eventpos) + while ((line = fgets (inbuf, sizeof (inbuf), logfile)) != NULL) { - line = fgets (inbuf, sizeof (inbuf), logfile); - /* End of input? */ - if (line == NULL) + /* End of current frame? + If we're the last frame, just read till the end of file. */ + if (cur_frame < last_cached_frame && + curpos >= stopframe[cur_frame + 1].eventpos) break; curpos = ftell (logfile); if (strstr (line, request) != NULL) |