diff options
author | Bruno Larsen <blarsen@redhat.com> | 2023-06-15 11:17:07 +0200 |
---|---|---|
committer | Bruno Larsen <blarsen@redhat.com> | 2023-07-14 10:58:17 +0200 |
commit | f52625f1f29a87e94aa9d40e1b76be2d0ecedc10 (patch) | |
tree | 53b8c986a4913bfe8404134a687e235d5db65ba8 /gdb/source.c | |
parent | 3e3a1874fcec34bcf51b4baf4be09aebab561bff (diff) | |
download | gdb-f52625f1f29a87e94aa9d40e1b76be2d0ecedc10.zip gdb-f52625f1f29a87e94aa9d40e1b76be2d0ecedc10.tar.gz gdb-f52625f1f29a87e94aa9d40e1b76be2d0ecedc10.tar.bz2 |
gdb/cli: Improve UX when using list with no args
When using "list" with no arguments, GDB will first print the lines
around where the inferior is stopped, then print the next N lines until
reaching the end of file, at which point it warns the user "Line X out
of range, file Y only has X-1 lines.". This is usually desirable, but
if the user can no longer see the original line, they may have forgotten
the current line or that a list command was used at all, making GDB's
error message look cryptic. It was reported in bugzilla as PR cli/30497.
This commit improves the user experience by changing the behavior of
"list" slightly when a user passes no arguments. It now prints that the
end of the file has been reached and recommends that the user use the
command "list ." instead.
Bug: https://sourceware.org/bugzilla/show_bug.cgi?id=30497
Reviewed-By: Eli Zaretskii <eliz@gnu.org>
Approved-By: Tom Tromey <tom@tromey.com>
Diffstat (limited to 'gdb/source.c')
-rw-r--r-- | gdb/source.c | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/gdb/source.c b/gdb/source.c index 9997ccc..08adc66 100644 --- a/gdb/source.c +++ b/gdb/source.c @@ -1484,6 +1484,22 @@ print_source_lines (struct symtab *s, source_lines_range line_range, line_range.stopline (), flags); } +/* See source.h. */ + +int +last_symtab_line (struct symtab *s) +{ + const std::vector<off_t> *offsets; + + /* Try to get the offsets for the start of each line. */ + if (!g_source_cache.get_line_charpos (s, &offsets)) + return false; + if (offsets == nullptr) + return false; + + return offsets->size (); +} + /* Print info on range of pc's in a specified line. */ |