diff options
author | Keith Seitz <keiths@redhat.com> | 2010-03-25 22:13:15 +0000 |
---|---|---|
committer | Keith Seitz <keiths@redhat.com> | 2010-03-25 22:13:15 +0000 |
commit | 418835cceca7eb0a5193eb476fe1733ab290adcc (patch) | |
tree | 386d9778a7bede3fe1cf2c2dc5f54f097948455c | |
parent | e62b8c7ea4e47e447df774f45308f9539cd99fd6 (diff) | |
download | gdb-418835cceca7eb0a5193eb476fe1733ab290adcc.zip gdb-418835cceca7eb0a5193eb476fe1733ab290adcc.tar.gz gdb-418835cceca7eb0a5193eb476fe1733ab290adcc.tar.bz2 |
* dwarf2read.c (read_subroutine_type): If the compilation unit
language is Java, mark any formal parameter named "this" as
artificial (GCC/43521).
(dwarf2_name): Add special handling for Java constructors.
-rw-r--r-- | gdb/ChangeLog | 7 | ||||
-rw-r--r-- | gdb/dwarf2read.c | 41 |
2 files changed, 47 insertions, 1 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog index d2c44c0..3bf6836 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,10 @@ +2010-03-25 Keith Seitz <keiths@redhat.com> + + * dwarf2read.c (read_subroutine_type): If the compilation unit + language is Java, mark any formal parameter named "this" as + artificial (GCC/43521). + (dwarf2_name): Add special handling for Java constructors. + 2010-03-25 Tom Tromey <tromey@redhat.com> PR gdb/11327, PR gdb/11328, PR breakpoints/11368: diff --git a/gdb/dwarf2read.c b/gdb/dwarf2read.c index 40f8cde..4de0797 100644 --- a/gdb/dwarf2read.c +++ b/gdb/dwarf2read.c @@ -5949,7 +5949,18 @@ read_subroutine_type (struct die_info *die, struct dwarf2_cu *cu) if (attr) TYPE_FIELD_ARTIFICIAL (ftype, iparams) = DW_UNSND (attr); else - TYPE_FIELD_ARTIFICIAL (ftype, iparams) = 0; + { + TYPE_FIELD_ARTIFICIAL (ftype, iparams) = 0; + + /* GCC/43521: In java, the formal parameter + "this" is sometimes not marked with DW_AT_artificial. */ + if (cu->language == language_java) + { + const char *name = dwarf2_name (child_die, cu); + if (name && !strcmp (name, "this")) + TYPE_FIELD_ARTIFICIAL (ftype, iparams) = 1; + } + } TYPE_FIELD_TYPE (ftype, iparams) = die_type (child_die, cu); iparams++; } @@ -9176,6 +9187,34 @@ dwarf2_name (struct die_info *die, struct dwarf2_cu *cu) /* These tags always have simple identifiers already; no need to canonicalize them. */ return DW_STRING (attr); + case DW_TAG_subprogram: + /* Java constructors will all be named "<init>", so return + the class name when we see this special case. */ + if (cu->language == language_java + && DW_STRING (attr) != NULL + && strcmp (DW_STRING (attr), "<init>") == 0) + { + struct dwarf2_cu *spec_cu = cu; + struct die_info *spec_die; + + /* GCJ will output '<init>' for Java constructor names. + For this special case, return the name of the parent class. */ + + /* GCJ may output suprogram DIEs with AT_specification set. + If so, use the name of the specified DIE. */ + spec_die = die_specification (die, &spec_cu); + if (spec_die != NULL) + return dwarf2_name (spec_die, spec_cu); + + do + { + die = die->parent; + if (die->tag == DW_TAG_class_type) + return dwarf2_name (die, cu); + } + while (die->tag != DW_TAG_compile_unit); + } + /* fall through */ default: if (!DW_STRING_IS_CANONICAL (attr)) { |