gdb: Remove an update of current_source_line and current_source_symtab
While reviewing some of the annotation code I noticed that identify_source_line (in source.c) sets current_source_line, current_source_symtab, and also calls clear_lines_listed_range. This seems a little strange, identify_source_line is really a wrapper around annotate_source, and is only called when annotation_level is greater than 0 (so annotations are turned on). It seems weird (to me) that when annotations are on we update GDB's idea of the "current" line/symtab, but when they are off we don't, given that annotations are really about communicating GDB's state to a user (GUI) and surely shouldn't be changing GDB's behaviour. This commit removes from identify_source_line all of the setting of current line/symtab and the call to clear_lines_listed_range, after doing this GDB still passes all tests, so I don't believe these lines were actually required. With this code removed identify_source_line is only a wrapper around annotate_source, so I moved identify_source_line to annotate.c and renamed it to annotate_source_line. gdb/ChangeLog: * annotate.c: Add 'source.h' and 'objfiles.h' includes. (annotate_source): Make static. (annotate_source_line): Moved from source.c and renamed from identify_source_line. Update the return type. * annotate.h (annotate_source): Delete declaration. (annotate_source_line): Declaration moved from source.h, and renamed from identify_source_line. Return type updated. * source.c (identify_source_line): Moved to annotate.c and renamed to annotate_source_line. (info_line_command): Remove check of annotation_level. * source.h (identify_source_line): Move declaration to annotate.h and rename to annotate_source_line. * stack.c: Add 'annotate.h' include. (print_frame_info): Remove check of annotation_level before calling annotate_source_line.
This commit is contained in:
parent
00df30ae1e
commit
0d3abd8cc9
6 changed files with 62 additions and 43 deletions
27
gdb/source.c
27
gdb/source.c
|
@ -1212,29 +1212,6 @@ open_source_file_with_line_charpos (struct symtab *s)
|
|||
|
||||
|
||||
|
||||
/* See source.h. */
|
||||
|
||||
int
|
||||
identify_source_line (struct symtab *s, int line, int mid_statement,
|
||||
CORE_ADDR pc)
|
||||
{
|
||||
if (s->line_charpos == nullptr)
|
||||
open_source_file_with_line_charpos (s);
|
||||
if (s->fullname == 0)
|
||||
return 0;
|
||||
if (line > s->nlines)
|
||||
/* Don't index off the end of the line_charpos array. */
|
||||
return 0;
|
||||
annotate_source (s->fullname, line, s->line_charpos[line - 1],
|
||||
mid_statement, get_objfile_arch (SYMTAB_OBJFILE (s)), pc);
|
||||
|
||||
current_source_line = line;
|
||||
current_source_symtab = s;
|
||||
clear_lines_listed_range ();
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
||||
/* Print source lines from the file of symtab S,
|
||||
starting with line number LINE and stopping before line number STOPLINE. */
|
||||
|
||||
|
@ -1519,8 +1496,8 @@ info_line_command (const char *arg, int from_tty)
|
|||
|
||||
/* If this is the only line, show the source code. If it could
|
||||
not find the file, don't do anything special. */
|
||||
if (annotation_level && sals.size () == 1)
|
||||
identify_source_line (sal.symtab, sal.line, 0, start_pc);
|
||||
if (sals.size () == 1)
|
||||
annotate_source_line (sal.symtab, sal.line, 0, start_pc);
|
||||
}
|
||||
else
|
||||
/* Is there any case in which we get here, and have an address
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue