[PATCHv2,3/3] gdb: Remove a use of VEC from dwarf2read.{c,h}

Message ID 0dcd5cbc1c863f32bbc513db657e3c2aec2dadb7.1569425799.git.andrew.burgess@embecosm.com
State Superseded
Headers show
Series
  • Remove some uses of VEC
Related show

Commit Message

Andrew Burgess Sept. 25, 2019, 3:54 p.m.
Removes a use of VEC from dwarf2read.{c,h} and replaces it with
std::vector.  As far as possible this is a like for like replacement
with minimal refactoring.

There should be no user visible changes after this commit.

gdb/ChangeLog:

	* dwarf2read.c (struct type_unit_group) <tus>: Convert to
	std::vector.
	(build_type_psymtabs_reader): Update for std::vector.
	(build_type_psymtab_dependencies): Likewise.
	* dwarf2read.h: Remove use of DEF_VEC_P.
	(typedef sig_type_ptr): Delete.
---
 gdb/ChangeLog    |  9 +++++++++
 gdb/dwarf2read.c | 16 ++++++++--------
 gdb/dwarf2read.h |  3 ---
 3 files changed, 17 insertions(+), 11 deletions(-)

-- 
2.14.5

Comments

Tom Tromey Sept. 25, 2019, 10:08 p.m. | #1
>>>>> "Andrew" == Andrew Burgess <andrew.burgess@embecosm.com> writes:


Andrew> Removes a use of VEC from dwarf2read.{c,h} and replaces it with
Andrew> std::vector.  As far as possible this is a like for like replacement
Andrew> with minimal refactoring.

Andrew> +  if (tu_group->tus == nullptr)
Andrew> +    tu_group->tus = new std::vector <signatured_type *>;
Andrew> +  tu_group->tus->push_back (sig_type);

Andrew> +  int len = tu_group->tus->size ();

Is it possible to reach here with tus==nullptr?

Andrew> +  for (i = 0; i < tu_group->tus->size (); ++i)

Likewise.

Andrew> -  VEC_free (sig_type_ptr, tu_group->tus);
Andrew> +  delete tu_group->tus;
 
VEC_free resets tus to nullptr, but I don't know whether or not that's
important.

Tom

Patch

diff --git a/gdb/dwarf2read.c b/gdb/dwarf2read.c
index 1052501c351..7cc0dc3c92d 100644
--- a/gdb/dwarf2read.c
+++ b/gdb/dwarf2read.c
@@ -620,7 +620,7 @@  struct type_unit_group
   /* The TUs that share this DW_AT_stmt_list entry.
      This is added to while parsing type units to build partial symtabs,
      and is deleted afterwards and not used again.  */
-  VEC (sig_type_ptr) *tus;
+  std::vector <signatured_type *> *tus;
 
   /* The compunit symtab.
      Type units in a group needn't all be defined in the same source file,
@@ -8184,7 +8184,9 @@  build_type_psymtabs_reader (const struct die_reader_specs *reader,
   attr = dwarf2_attr_no_follow (type_unit_die, DW_AT_stmt_list);
   tu_group = get_type_unit_group (cu, attr);
 
-  VEC_safe_push (sig_type_ptr, tu_group->tus, sig_type);
+  if (tu_group->tus == nullptr)
+    tu_group->tus = new std::vector <signatured_type *>;
+  tu_group->tus->push_back (sig_type);
 
   prepare_one_comp_unit (cu, type_unit_die, language_minimal);
   pst = create_partial_symtab (per_cu, "");
@@ -8341,8 +8343,7 @@  build_type_psymtab_dependencies (void **slot, void *info)
   struct type_unit_group *tu_group = (struct type_unit_group *) *slot;
   struct dwarf2_per_cu_data *per_cu = &tu_group->per_cu;
   struct partial_symtab *pst = per_cu->v.psymtab;
-  int len = VEC_length (sig_type_ptr, tu_group->tus);
-  struct signatured_type *iter;
+  int len = tu_group->tus->size ();
   int i;
 
   gdb_assert (len > 0);
@@ -8350,16 +8351,15 @@  build_type_psymtab_dependencies (void **slot, void *info)
 
   pst->number_of_dependencies = len;
   pst->dependencies = objfile->partial_symtabs->allocate_dependencies (len);
-  for (i = 0;
-       VEC_iterate (sig_type_ptr, tu_group->tus, i, iter);
-       ++i)
+  for (i = 0; i < tu_group->tus->size (); ++i)
     {
+      struct signatured_type *iter = tu_group->tus->at (i);
       gdb_assert (iter->per_cu.is_debug_types);
       pst->dependencies[i] = iter->per_cu.v.psymtab;
       iter->type_unit_group = tu_group;
     }
 
-  VEC_free (sig_type_ptr, tu_group->tus);
+  delete tu_group->tus;
 
   return 1;
 }
diff --git a/gdb/dwarf2read.h b/gdb/dwarf2read.h
index d5a02990d41..aee8742a79c 100644
--- a/gdb/dwarf2read.h
+++ b/gdb/dwarf2read.h
@@ -401,9 +401,6 @@  struct signatured_type
   struct dwo_unit *dwo_unit;
 };
 
-typedef struct signatured_type *sig_type_ptr;
-DEF_VEC_P (sig_type_ptr);
-
 ULONGEST read_unsigned_leb128 (bfd *, const gdb_byte *, unsigned int *);
 
 /* This represents a '.dwz' file.  */