forked from Imagelibrary/binutils-gdb
gdb: Remove support for old mangling schemes
An upcoming sync with gcc's libiberty [1] will remove support for old mangling schemes (GNU v2, Lucid, ARM, HP and EDG). It will remove the cplus_demangle_opname function, so we need to get rid of its usages in GDB (it's a GNU v2 specific function). I think the changes are mostly relatively obvious, some hacks that were necessary to support overloaded operators with GNU v2 mangling are not needed anymore. The change in stabsread.c is perhaps less obvious. I think we could get rid of more code in that region that is specific to old mangling schemes, but I chose to do only the minimal changes required to remove the cplus_demangle_opname uses. There is also a detailed comment just above that explaining how GNU v2 and v3 mangled symbols are handled, I decided to leave it as-is, since I wasn't sure which part to remove, change or leave there. [1] The commit "Remove support for demangling GCC 2.x era mangling schemes.", specifically. gdb/ChangeLog: * gdbtypes.c (check_stub_method_group): Remove handling of old mangling schemes. * linespec.c (find_methods): Likewise. * stabsread.c (read_member_functions): Likewise. * valops.c (search_struct_method): Likewise. (value_struct_elt_for_reference): Likewise. * NEWS: Mention this change. gdb/testsuite/ChangeLog: * gdb.cp/demangle.exp (test_gnu_style_demangling): Rename to... (test_gnuv3_style_demangling): ... this. (test_lucid_style_demangling): Remove. (test_arm_style_demangling): Remove. (test_hp_style_demangling): Remove. (do_tests): Remove calls to the above. gdb/doc/ChangeLog: * gdb.texinfo (Print Settings): Remove mention of specific demangle-style values, just refer to the in-process help.
This commit is contained in:
@@ -2736,37 +2736,11 @@ check_stub_method_group (struct type *type, int method_id)
|
||||
{
|
||||
int len = TYPE_FN_FIELDLIST_LENGTH (type, method_id);
|
||||
struct fn_field *f = TYPE_FN_FIELDLIST1 (type, method_id);
|
||||
int j, found_stub = 0;
|
||||
|
||||
for (j = 0; j < len; j++)
|
||||
if (TYPE_FN_FIELD_STUB (f, j))
|
||||
{
|
||||
found_stub = 1;
|
||||
check_stub_method (type, method_id, j);
|
||||
}
|
||||
|
||||
/* GNU v3 methods with incorrect names were corrected when we read
|
||||
in type information, because it was cheaper to do it then. The
|
||||
only GNU v2 methods with incorrect method names are operators and
|
||||
destructors; destructors were also corrected when we read in type
|
||||
information.
|
||||
|
||||
Therefore the only thing we need to handle here are v2 operator
|
||||
names. */
|
||||
if (found_stub && !startswith (TYPE_FN_FIELD_PHYSNAME (f, 0), "_Z"))
|
||||
for (int j = 0; j < len; j++)
|
||||
{
|
||||
int ret;
|
||||
char dem_opname[256];
|
||||
|
||||
ret = cplus_demangle_opname (TYPE_FN_FIELDLIST_NAME (type,
|
||||
method_id),
|
||||
dem_opname, DMGL_ANSI);
|
||||
if (!ret)
|
||||
ret = cplus_demangle_opname (TYPE_FN_FIELDLIST_NAME (type,
|
||||
method_id),
|
||||
dem_opname, 0);
|
||||
if (ret)
|
||||
TYPE_FN_FIELDLIST_NAME (type, method_id) = xstrdup (dem_opname);
|
||||
if (TYPE_FN_FIELD_STUB (f, j))
|
||||
check_stub_method (type, method_id, j);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user