From: Fred Fish Date: Sun, 9 Dec 2001 23:17:07 +0000 (+0000) Subject: Approved by Elena Zannoni: X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=2f038fcb08e51676d382e60acb6a9c1a985df635;p=binutils-gdb.git Approved by Elena Zannoni: 2001-12-08 Fred Fish * 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. --- diff --git a/gdb/ChangeLog b/gdb/ChangeLog index e96158f783c..cfac5d13c00 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,9 @@ +2001-12-08 Fred Fish + + * 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 * mdebugread.c (cross_ref): Pass TYPE_FLAG_STUB to init_type() diff --git a/gdb/dwarf2read.c b/gdb/dwarf2read.c index fc149cde799..aab1d46676b 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); } }