================ @@ -375,16 +375,21 @@ std::vector<DWARFDIE> DWARFDIE::GetDeclContextDIEs() const { std::vector<lldb_private::CompilerContext> DWARFDIE::GetDeclContext() const { std::vector<lldb_private::CompilerContext> context; - const dw_tag_t tag = Tag(); - if (tag == DW_TAG_compile_unit || tag == DW_TAG_partial_unit) - return context; DWARFDIE parent = GetParent(); - if (parent) + if (parent) { + const dw_tag_t parent_tag = parent.Tag(); + if (parent_tag == DW_TAG_compile_unit || parent_tag == DW_TAG_partial_unit) + // Handle top-level DIEs by following the specification if any. + if (DWARFDIE spec = GetReferencedDIE(DW_AT_specification)) + if (spec != *this) ---------------- felipepiovezan wrote:
Nit, If you feel so inclined: ``` if (DWARFDIE spec = GetReferencedDIE(DW_AT_specification); spec && spec != *this) ``` https://github.com/llvm/llvm-project/pull/77157 _______________________________________________ lldb-commits mailing list lldb-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-commits