mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2024-12-09 04:21:49 +08:00
Add attribute::as_virtuality method
This adds a new attribute::as_virtuality method and changes the DWARF reader to use it. This also ensures that the attibute's form will now be respected. gdb/ChangeLog 2020-09-29 Tom Tromey <tom@tromey.com> * dwarf2/read.c (dwarf2_add_field, dwarf2_add_member_fn): Update. * dwarf2/attribute.h (struct attribute) <as_virtuality>: New method. * dwarf2/attribute.c (attribute::as_virtuality): New method.
This commit is contained in:
parent
52c14d1128
commit
23dca5c3d7
@ -1,3 +1,10 @@
|
||||
2020-09-29 Tom Tromey <tom@tromey.com>
|
||||
|
||||
* dwarf2/read.c (dwarf2_add_field, dwarf2_add_member_fn): Update.
|
||||
* dwarf2/attribute.h (struct attribute) <as_virtuality>: New
|
||||
method.
|
||||
* dwarf2/attribute.c (attribute::as_virtuality): New method.
|
||||
|
||||
2020-09-29 Tom Tromey <tom@tromey.com>
|
||||
|
||||
* dwarf2/die.h (struct die_info) <addr_base, ranges_base>: Check
|
||||
|
@ -222,3 +222,26 @@ attribute::defaulted () const
|
||||
plongest (value));
|
||||
return DW_DEFAULTED_no;
|
||||
}
|
||||
|
||||
/* See attribute.h. */
|
||||
|
||||
dwarf_virtuality_attribute
|
||||
attribute::as_virtuality () const
|
||||
{
|
||||
LONGEST value = constant_value (-1);
|
||||
|
||||
switch (value)
|
||||
{
|
||||
case DW_VIRTUALITY_none:
|
||||
case DW_VIRTUALITY_virtual:
|
||||
case DW_VIRTUALITY_pure_virtual:
|
||||
return (dwarf_virtuality_attribute) value;
|
||||
}
|
||||
|
||||
/* If the form was not constant, we already complained in
|
||||
constant_value, so there's no need to complain again. */
|
||||
if (form_is_constant ())
|
||||
complaint (_("unrecognized DW_AT_virtuality value (%s)"),
|
||||
plongest (value));
|
||||
return DW_VIRTUALITY_none;
|
||||
}
|
||||
|
@ -258,6 +258,11 @@ struct attribute
|
||||
returned. */
|
||||
dwarf_defaulted_attribute defaulted () const;
|
||||
|
||||
/* Return the attribute's value as a dwarf_virtuality_attribute
|
||||
constant according to DWARF spec. An unrecognized value will
|
||||
issue a complaint and return DW_VIRTUALITY_none. */
|
||||
dwarf_virtuality_attribute as_virtuality () const;
|
||||
|
||||
ENUM_BITFIELD(dwarf_attribute) name : 15;
|
||||
|
||||
/* A boolean that is used for forms that require reprocessing. A
|
||||
|
@ -15021,7 +15021,7 @@ dwarf2_add_field (struct field_info *fip, struct die_info *die,
|
||||
|
||||
attr = dwarf2_attr (die, DW_AT_virtuality, cu);
|
||||
if (attr != nullptr)
|
||||
new_field->virtuality = DW_UNSND (attr);
|
||||
new_field->virtuality = attr->as_virtuality ();
|
||||
else
|
||||
new_field->virtuality = DW_VIRTUALITY_none;
|
||||
|
||||
@ -15722,7 +15722,7 @@ dwarf2_add_member_fn (struct field_info *fip, struct die_info *die,
|
||||
else
|
||||
{
|
||||
attr = dwarf2_attr (die, DW_AT_virtuality, cu);
|
||||
if (attr && DW_UNSND (attr))
|
||||
if (attr != nullptr && attr->as_virtuality () != DW_VIRTUALITY_none)
|
||||
{
|
||||
/* GCC does this, as of 2008-08-25; PR debug/37237. */
|
||||
complaint (_("Member function \"%s\" (offset %s) is virtual "
|
||||
|
Loading…
Reference in New Issue
Block a user