diff options
author | Fred Fish <fnf@specifix.com> | 2001-12-09 23:17:07 +0000 |
---|---|---|
committer | Fred Fish <fnf@specifix.com> | 2001-12-09 23:17:07 +0000 |
commit | 2f038fcb08e51676d382e60acb6a9c1a985df635 (patch) | |
tree | 00d7c8a1bc1f2c4c73864e146c206413c4d1b5f6 | |
parent | 6251c3aa9e401e7532f4e5e439326a5710ae90f7 (diff) | |
download | gdb-2f038fcb08e51676d382e60acb6a9c1a985df635.zip gdb-2f038fcb08e51676d382e60acb6a9c1a985df635.tar.gz gdb-2f038fcb08e51676d382e60acb6a9c1a985df635.tar.bz2 |
Approved by Elena Zannoni:
2001-12-08 Fred Fish <fnf@redhat.com>
* dwarf2read.c (read_typedef): Replace hand crafted type
initialization with a call to the init_type() function, which
is how the rest of gdb creates types.
-rw-r--r-- | gdb/ChangeLog | 6 | ||||
-rw-r--r-- | gdb/dwarf2read.c | 22 |
2 files changed, 13 insertions, 15 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog index e96158f7..cfac5d1 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,9 @@ +2001-12-08 Fred Fish <fnf@redhat.com> + + * dwarf2read.c (read_typedef): Replace hand crafted type + initialization with a call to the init_type() function, which + is how the rest of gdb creates types. + 2001-12-09 Fred Fish <fnf@redhat.com> * mdebugread.c (cross_ref): Pass TYPE_FLAG_STUB to init_type() diff --git a/gdb/dwarf2read.c b/gdb/dwarf2read.c index fc149cd..aab1d46 100644 --- a/gdb/dwarf2read.c +++ b/gdb/dwarf2read.c @@ -2882,26 +2882,18 @@ static void read_typedef (struct die_info *die, struct objfile *objfile, const struct comp_unit_head *cu_header) { - struct type *type; + struct attribute *attr; + char *name = NULL; if (!die->type) { - struct attribute *attr; - struct type *xtype; - - xtype = die_type (die, objfile, cu_header); - - type = alloc_type (objfile); - TYPE_CODE (type) = TYPE_CODE_TYPEDEF; - TYPE_FLAGS (type) |= TYPE_FLAG_TARGET_STUB; - TYPE_TARGET_TYPE (type) = xtype; attr = dwarf_attr (die, DW_AT_name); if (attr && DW_STRING (attr)) - TYPE_NAME (type) = obsavestring (DW_STRING (attr), - strlen (DW_STRING (attr)), - &objfile->type_obstack); - - die->type = type; + { + name = DW_STRING (attr); + } + die->type = init_type (TYPE_CODE_TYPEDEF, 0, TYPE_FLAG_TARGET_STUB, name, objfile); + TYPE_TARGET_TYPE (die->type) = die_type (die, objfile, cu_header); } } |