This cleanup is designed to make the https://reviews.llvm.org/D32167 patch smaller and easier to read. Cleanup in this patch: Allow DWARFUnit subclasses to hand out the data that should be used when decoding data for a DIE. The information might be in .debug_info or could be in .debug_types. There is a new virtual function on DWARFUnit that each subclass must override: virtual const lldb_private::DWARFDataExtractor &DWARFUnit::GetData() const; This allows DWARFCompileUnit and eventually DWARFTypeUnit to hand out different data to be used when decoding the DIE information. Add a new pure virtual function to get the size of the DWARF unit header: virtual uint32_t DWARFUnit::GetHeaderByteSize() const = 0; This allows DWARFCompileUnit and eventually DWARFTypeUnit to hand out different offsets where the first DIE starts when decoding DIE information from the unit. Added a new function to DWARFDataExtractor to get the size of an offset: size_t DWARFDataExtractor::GetDWARFSizeOfOffset() const; Removed dead dumping and parsing code in the DWARFDebugInfo class. Inlined a bunch of calls in DWARFUnit for accessors that were just returning integer member variables. Renamed DWARFUnit::Size() to DWARFUnit::GetHeaderByteSize() as it clearly states what it is doing and makes more sense. Differential Revision: https://reviews.llvm.org/D46606 llvm-svn: 331892
74 lines
2.3 KiB
C++
74 lines
2.3 KiB
C++
//===-- DWARFAttribute.cpp --------------------------------------*- C++ -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "DWARFAttribute.h"
|
|
#include "DWARFUnit.h"
|
|
#include "DWARFDebugInfo.h"
|
|
|
|
DWARFAttributes::DWARFAttributes() : m_infos() {}
|
|
|
|
DWARFAttributes::~DWARFAttributes() {}
|
|
|
|
uint32_t DWARFAttributes::FindAttributeIndex(dw_attr_t attr) const {
|
|
collection::const_iterator end = m_infos.end();
|
|
collection::const_iterator beg = m_infos.begin();
|
|
collection::const_iterator pos;
|
|
for (pos = beg; pos != end; ++pos) {
|
|
if (pos->attr.get_attr() == attr)
|
|
return std::distance(beg, pos);
|
|
}
|
|
return UINT32_MAX;
|
|
}
|
|
|
|
void DWARFAttributes::Append(const DWARFUnit *cu,
|
|
dw_offset_t attr_die_offset, dw_attr_t attr,
|
|
dw_form_t form) {
|
|
AttributeValue attr_value = {cu, attr_die_offset, {attr, form}};
|
|
m_infos.push_back(attr_value);
|
|
}
|
|
|
|
bool DWARFAttributes::ContainsAttribute(dw_attr_t attr) const {
|
|
return FindAttributeIndex(attr) != UINT32_MAX;
|
|
}
|
|
|
|
bool DWARFAttributes::RemoveAttribute(dw_attr_t attr) {
|
|
uint32_t attr_index = FindAttributeIndex(attr);
|
|
if (attr_index != UINT32_MAX) {
|
|
m_infos.erase(m_infos.begin() + attr_index);
|
|
return true;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
bool DWARFAttributes::ExtractFormValueAtIndex(
|
|
uint32_t i, DWARFFormValue &form_value) const {
|
|
const DWARFUnit *cu = CompileUnitAtIndex(i);
|
|
form_value.SetCompileUnit(cu);
|
|
form_value.SetForm(FormAtIndex(i));
|
|
lldb::offset_t offset = DIEOffsetAtIndex(i);
|
|
return form_value.ExtractValue(cu->GetData(), &offset);
|
|
}
|
|
|
|
uint64_t DWARFAttributes::FormValueAsUnsigned(dw_attr_t attr,
|
|
uint64_t fail_value) const {
|
|
const uint32_t attr_idx = FindAttributeIndex(attr);
|
|
if (attr_idx != UINT32_MAX)
|
|
return FormValueAsUnsignedAtIndex(attr_idx, fail_value);
|
|
return fail_value;
|
|
}
|
|
|
|
uint64_t
|
|
DWARFAttributes::FormValueAsUnsignedAtIndex(uint32_t i,
|
|
uint64_t fail_value) const {
|
|
DWARFFormValue form_value;
|
|
if (ExtractFormValueAtIndex(i, form_value))
|
|
return form_value.Reference();
|
|
return fail_value;
|
|
}
|