gdb/dwarf: pass a file_entry to line_header::file_file_name
In the following patch, there will be some callers of file_file_name that will already have access to the file_entry object for which they want the file name. It would be inefficient to have them pass an index, only for line_header::file_file_name to re-lookup the same file_entry object. Change line_header::file_file_name to accept a file_entry object reference, instead of an index to look up. I think this change makes sense in any case. Callers that have an index can first obtain a file_entry using line_header::file_name_at or line_header::file_names. When passing a file_entry object, we can assume that the file_entry's index is valid, unlike when passing an index. So, push the special case about an invalid index to the sole current caller of file_file_name, macro_start_file. I think that error belongs there anyway, since it specifically talks about "bad file number in macro information". This requires recording the file index in the file_entry structure, so add that. Change-Id: Ic6e44c407539d92b7863d7ba82405ade17f384ad
This commit is contained in:
parent
ddc01737d3
commit
0aa306fed3
3 changed files with 36 additions and 37 deletions
|
@ -48,47 +48,28 @@ line_header::add_file_name (const char *name,
|
||||||
unsigned int mod_time,
|
unsigned int mod_time,
|
||||||
unsigned int length)
|
unsigned int length)
|
||||||
{
|
{
|
||||||
|
file_name_index index
|
||||||
|
= version >= 5 ? file_names_size (): file_names_size () + 1;
|
||||||
|
|
||||||
if (dwarf_line_debug >= 2)
|
if (dwarf_line_debug >= 2)
|
||||||
{
|
gdb_printf (gdb_stdlog, "Adding file %d: %s\n", index, name);
|
||||||
size_t new_size;
|
|
||||||
if (version >= 5)
|
m_file_names.emplace_back (name, index, d_index, mod_time, length);
|
||||||
new_size = file_names_size ();
|
|
||||||
else
|
|
||||||
new_size = file_names_size () + 1;
|
|
||||||
gdb_printf (gdb_stdlog, "Adding file %zu: %s\n",
|
|
||||||
new_size, name);
|
|
||||||
}
|
|
||||||
m_file_names.emplace_back (name, d_index, mod_time, length);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string
|
std::string
|
||||||
line_header::file_file_name (int file) const
|
line_header::file_file_name (const file_entry &fe) const
|
||||||
{
|
{
|
||||||
/* Is the file number a valid index into the line header's file name
|
gdb_assert (is_valid_file_index (fe.index));
|
||||||
table? Remember that file numbers start with one, not zero. */
|
|
||||||
if (is_valid_file_index (file))
|
|
||||||
{
|
|
||||||
const file_entry *fe = file_name_at (file);
|
|
||||||
|
|
||||||
if (!IS_ABSOLUTE_PATH (fe->name))
|
if (IS_ABSOLUTE_PATH (fe.name))
|
||||||
{
|
return fe.name;
|
||||||
const char *dir = fe->include_dir (this);
|
|
||||||
if (dir != NULL)
|
|
||||||
return path_join (dir, fe->name);
|
|
||||||
}
|
|
||||||
|
|
||||||
return fe->name;
|
const char *dir = fe.include_dir (this);
|
||||||
}
|
if (dir == nullptr)
|
||||||
else
|
return fe.name;
|
||||||
{
|
|
||||||
/* The compiler produced a bogus file number. We can at least
|
|
||||||
record the macro definitions made in the file, even if we
|
|
||||||
won't be able to find the file by name. */
|
|
||||||
complaint (_("bad file number in macro information (%d)"),
|
|
||||||
file);
|
|
||||||
|
|
||||||
return string_printf ("<bad macro file number %d>", file);
|
return path_join (dir, fe.name);
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
|
|
@ -36,9 +36,10 @@ struct file_entry
|
||||||
{
|
{
|
||||||
file_entry () = default;
|
file_entry () = default;
|
||||||
|
|
||||||
file_entry (const char *name_, dir_index d_index_,
|
file_entry (const char *name_, file_name_index index_, dir_index d_index_,
|
||||||
unsigned int mod_time_, unsigned int length_)
|
unsigned int mod_time_, unsigned int length_)
|
||||||
: name (name_),
|
: name (name_),
|
||||||
|
index (index_),
|
||||||
d_index (d_index_),
|
d_index (d_index_),
|
||||||
mod_time (mod_time_),
|
mod_time (mod_time_),
|
||||||
length (length_)
|
length (length_)
|
||||||
|
@ -52,6 +53,9 @@ struct file_entry
|
||||||
owned by debug_line_buffer. */
|
owned by debug_line_buffer. */
|
||||||
const char *name {};
|
const char *name {};
|
||||||
|
|
||||||
|
/* The index of this file in the file table. */
|
||||||
|
file_name_index index {};
|
||||||
|
|
||||||
/* The directory index (1-based). */
|
/* The directory index (1-based). */
|
||||||
dir_index d_index {};
|
dir_index d_index {};
|
||||||
|
|
||||||
|
@ -168,8 +172,8 @@ struct line_header
|
||||||
const gdb_byte *statement_program_start {}, *statement_program_end {};
|
const gdb_byte *statement_program_start {}, *statement_program_end {};
|
||||||
|
|
||||||
/* Return file name relative to the compilation directory of file
|
/* Return file name relative to the compilation directory of file
|
||||||
number FILE in this object's file name table. */
|
FE in this object's file name table. */
|
||||||
std::string file_file_name (int file) const;
|
std::string file_file_name (const file_entry &fe) const;
|
||||||
|
|
||||||
/* Return the compilation directory of the compilation unit in the context of
|
/* Return the compilation directory of the compilation unit in the context of
|
||||||
which this line header is read. Return nullptr if non applicable. */
|
which this line header is read. Return nullptr if non applicable. */
|
||||||
|
|
|
@ -52,7 +52,21 @@ macro_start_file (buildsym_compunit *builder,
|
||||||
const struct line_header *lh)
|
const struct line_header *lh)
|
||||||
{
|
{
|
||||||
/* File name relative to the compilation directory of this source file. */
|
/* File name relative to the compilation directory of this source file. */
|
||||||
std::string file_name = lh->file_file_name (file);
|
const file_entry *fe = lh->file_name_at (file);
|
||||||
|
std::string file_name;
|
||||||
|
|
||||||
|
if (fe != nullptr)
|
||||||
|
file_name = lh->file_file_name (*fe);
|
||||||
|
else
|
||||||
|
{
|
||||||
|
/* The compiler produced a bogus file number. We can at least
|
||||||
|
record the macro definitions made in the file, even if we
|
||||||
|
won't be able to find the file by name. */
|
||||||
|
complaint (_("bad file number in macro information (%d)"),
|
||||||
|
file);
|
||||||
|
|
||||||
|
file_name = string_printf ("<bad macro file number %d>", file);
|
||||||
|
}
|
||||||
|
|
||||||
if (! current_file)
|
if (! current_file)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Add table
Reference in a new issue