}
return "";
case DW_TAG_subprogram:
- /* Nested subroutines in Fortran get a prefix with the name
- of the parent's subroutine. Entry points are prefixed by the
- parent's namespace. */
- if (cu->lang () == language_fortran)
- {
- if ((die->tag == DW_TAG_subprogram)
- && (dwarf2_name (parent, cu) != NULL))
- return dwarf2_name (parent, cu);
- else if (die->tag == DW_TAG_entry_point)
- return determine_prefix (parent, cu);
- }
- else if (cu->lang () == language_ada
- && (die->tag == DW_TAG_subprogram
- || die->tag == DW_TAG_inlined_subroutine
- || die->tag == DW_TAG_lexical_block))
- return dwarf2_full_name (nullptr, parent, cu);
- return "";
+ {
+ const char *name = nullptr;
+ /* Nested subroutines in Fortran get a prefix with the name
+ of the parent's subroutine. Entry points are prefixed by the
+ parent's namespace. */
+ if (cu->lang () == language_fortran)
+ {
+ if ((die->tag == DW_TAG_subprogram)
+ && (dwarf2_name (parent, cu) != NULL))
+ name = dwarf2_name (parent, cu);
+ else if (die->tag == DW_TAG_entry_point)
+ name = determine_prefix (parent, cu);
+ }
+ else if (cu->lang () == language_ada
+ && (die->tag == DW_TAG_subprogram
+ || die->tag == DW_TAG_inlined_subroutine
+ || die->tag == DW_TAG_lexical_block))
+ name = dwarf2_full_name (nullptr, parent, cu);
+ if (name == nullptr)
+ name = "";
+ return name;
+ }
case DW_TAG_enumeration_type:
parent_type = read_type_die (parent, cu);
if (parent_type->is_declared_class ())