gdb/dwarf: pass a file_entry to line_header::file_file_name
authorSimon Marchi <simon.marchi@polymtl.ca>
Wed, 27 Apr 2022 02:50:22 +0000 (22:50 -0400)
committerSimon Marchi <simon.marchi@polymtl.ca>
Sat, 30 Jul 2022 00:54:49 +0000 (20:54 -0400)
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

gdb/dwarf2/line-header.c
gdb/dwarf2/line-header.h
gdb/dwarf2/macro.c

index 13379851b9b64a776458b4f9c8d3cd03fa4e2e34..a1bd39df7eda7db0d3691a6337c9a3b3166025f4 100644 (file)
@@ -48,47 +48,28 @@ line_header::add_file_name (const char *name,
                            unsigned int mod_time,
                            unsigned int length)
 {
+  file_name_index index
+    = version >= 5 ? file_names_size (): file_names_size () + 1;
+
   if (dwarf_line_debug >= 2)
-    {
-      size_t new_size;
-      if (version >= 5)
-       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);
+    gdb_printf (gdb_stdlog, "Adding file %d: %s\n", index, name);
+
+  m_file_names.emplace_back (name, index, d_index, mod_time, length);
 }
 
 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
-     table?  Remember that file numbers start with one, not zero.  */
-  if (is_valid_file_index (file))
-    {
-      const file_entry *fe = file_name_at (file);
+  gdb_assert (is_valid_file_index (fe.index));
 
-      if (!IS_ABSOLUTE_PATH (fe->name))
-       {
-         const char *dir = fe->include_dir (this);
-         if (dir != NULL)
-           return path_join (dir, fe->name);
-       }
+  if (IS_ABSOLUTE_PATH (fe.name))
+    return fe.name;
 
-      return fe->name;
-    }
-  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);
+  const char *dir = fe.include_dir (this);
+  if (dir == nullptr)
+    return fe.name;
 
-      return string_printf ("<bad macro file number %d>", file);
-    }
+  return path_join (dir, fe.name);
 }
 
 static void
index 32f52c4a6477abd49e10fec992daf8de1424aeac..e6b52f7520e22293bc20407945e11ef414d659e4 100644 (file)
@@ -36,9 +36,10 @@ struct file_entry
 {
   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_)
     : name (name_),
+      index (index_),
       d_index (d_index_),
       mod_time (mod_time_),
       length (length_)
@@ -52,6 +53,9 @@ struct file_entry
      owned by debug_line_buffer.  */
   const char *name {};
 
+  /* The index of this file in the file table.  */
+  file_name_index index {};
+
   /* The directory index (1-based).  */
   dir_index d_index {};
 
@@ -168,8 +172,8 @@ struct line_header
   const gdb_byte *statement_program_start {}, *statement_program_end {};
 
   /* Return file name relative to the compilation directory of file
-     number FILE in this object's file name table.  */
-  std::string file_file_name (int file) const;
+     FE in this object's file name table.  */
+  std::string file_file_name (const file_entry &fe) const;
 
   /* Return the compilation directory of the compilation unit in the context of
      which this line header is read.  Return nullptr if non applicable.  */
index 99c3653a2c3a27cf264346cdb35deeb6c4d9dbc9..38c0fdfec738ebde886070d7a2ecd7b8babbd34f 100644 (file)
@@ -52,7 +52,21 @@ macro_start_file (buildsym_compunit *builder,
                  const struct line_header *lh)
 {
   /* 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)
     {