mirror of
git://gcc.gnu.org/git/gcc.git
synced 2025-01-25 07:34:00 +08:00
dwarf2out.c (gen_subprogram_die): Don't reuse the in-class decl for the abstract instance of an inline function.
* dwarf2out.c (gen_subprogram_die): Don't reuse the in-class decl for the abstract instance of an inline function. From-SVN: r39137
This commit is contained in:
parent
20342a6bc1
commit
cb9e9d8dd1
@ -1,3 +1,8 @@
|
||||
2001-01-19 Jason Merrill <jason@redhat.com>
|
||||
|
||||
* dwarf2out.c (gen_subprogram_die): Don't reuse the in-class decl
|
||||
for the abstract instance of an inline function.
|
||||
|
||||
Fri Jan 19 14:31:35 2001 Alexandre Oliva <aoliva@redhat.com>, J"orn Rennecke <amylaar@redhat.com>
|
||||
|
||||
* reload1.c (move2add_note_store): Treat all registers directly or
|
||||
|
@ -9868,12 +9868,11 @@ gen_subprogram_die (decl, context_die)
|
||||
/* If the definition comes from the same place as the declaration,
|
||||
maybe use the old DIE. We always want the DIE for this function
|
||||
that has the *_pc attributes to be under comp_unit_die so the
|
||||
debugger can find it. For inlines, that is the concrete instance,
|
||||
so we can use the old DIE here. For non-inline methods, we want a
|
||||
specification DIE at toplevel, so we need a new DIE. For local
|
||||
class methods, this doesn't apply; we just use the old DIE. */
|
||||
if ((DECL_ABSTRACT (decl) || old_die->die_parent == comp_unit_die
|
||||
|| context_die == NULL)
|
||||
debugger can find it. We also need to do this for abstract
|
||||
instances of inlines, since the spec requires the out-of-line copy
|
||||
to have the same parent. For local class methods, this doesn't
|
||||
apply; we just use the old DIE. */
|
||||
if ((old_die->die_parent == comp_unit_die || context_die == NULL)
|
||||
&& (DECL_ARTIFICIAL (decl)
|
||||
|| (get_AT_unsigned (old_die, DW_AT_decl_file) == file_index
|
||||
&& (get_AT_unsigned (old_die, DW_AT_decl_line)
|
||||
|
Loading…
Reference in New Issue
Block a user