Make DWARFAcceleratorTable::dump() const.

As dump() methods  should be. To allow that, do not store the DWARFFormValue
objects used for the dump in the header data.

Per Alexey's suggestion!

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@222436 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Frederic Riss 2014-11-20 16:21:11 +00:00
parent d239f8c198
commit 12385e603f
2 changed files with 12 additions and 9 deletions

View File

@ -40,14 +40,14 @@ bool DWARFAcceleratorTable::extract() {
for (unsigned i = 0; i < NumAtoms; ++i) { for (unsigned i = 0; i < NumAtoms; ++i) {
uint16_t AtomType = AccelSection.getU16(&Offset); uint16_t AtomType = AccelSection.getU16(&Offset);
DWARFFormValue AtomForm(AccelSection.getU16(&Offset)); uint16_t AtomForm = AccelSection.getU16(&Offset);
HdrData.Atoms.push_back(std::make_pair(AtomType, AtomForm)); HdrData.Atoms.push_back(std::make_pair(AtomType, AtomForm));
} }
return true; return true;
} }
void DWARFAcceleratorTable::dump(raw_ostream &OS) { void DWARFAcceleratorTable::dump(raw_ostream &OS) const {
// Dump the header. // Dump the header.
OS << "Magic = " << format("0x%08x", Hdr.Magic) << '\n' OS << "Magic = " << format("0x%08x", Hdr.Magic) << '\n'
<< "Version = " << format("0x%04x", Hdr.Version) << '\n' << "Version = " << format("0x%04x", Hdr.Version) << '\n'
@ -59,6 +59,7 @@ void DWARFAcceleratorTable::dump(raw_ostream &OS) {
<< "Number of atoms = " << HdrData.Atoms.size() << '\n'; << "Number of atoms = " << HdrData.Atoms.size() << '\n';
unsigned i = 0; unsigned i = 0;
SmallVector<DWARFFormValue, 3> AtomForms;
for (const auto &Atom: HdrData.Atoms) { for (const auto &Atom: HdrData.Atoms) {
OS << format("Atom[%d] Type: ", i++); OS << format("Atom[%d] Type: ", i++);
if (const char *TypeString = dwarf::AtomTypeString(Atom.first)) if (const char *TypeString = dwarf::AtomTypeString(Atom.first))
@ -66,11 +67,12 @@ void DWARFAcceleratorTable::dump(raw_ostream &OS) {
else else
OS << format("DW_ATOM_Unknown_0x%x", Atom.first); OS << format("DW_ATOM_Unknown_0x%x", Atom.first);
OS << " Form: "; OS << " Form: ";
if (const char *FormString = dwarf::FormEncodingString(Atom.second.getForm())) if (const char *FormString = dwarf::FormEncodingString(Atom.second))
OS << FormString; OS << FormString;
else else
OS << format("DW_FORM_Unknown_0x%x", Atom.second.getForm()); OS << format("DW_FORM_Unknown_0x%x", Atom.second);
OS << '\n'; OS << '\n';
AtomForms.push_back(DWARFFormValue(Atom.second));
} }
// Now go through the actual tables and dump them. // Now go through the actual tables and dump them.
@ -114,10 +116,10 @@ void DWARFAcceleratorTable::dump(raw_ostream &OS) {
for (unsigned Data = 0; Data < NumData; ++Data) { for (unsigned Data = 0; Data < NumData; ++Data) {
OS << format(" Data[%d] => ", Data); OS << format(" Data[%d] => ", Data);
unsigned i = 0; unsigned i = 0;
for (auto &Atom : HdrData.Atoms) { for (auto &Atom : AtomForms) {
OS << format("{Atom[%d]: ", i++); OS << format("{Atom[%d]: ", i++);
if (Atom.second.extractValue(AccelSection, &DataOffset, nullptr)) if (Atom.extractValue(AccelSection, &DataOffset, nullptr))
Atom.second.dump(OS, nullptr); Atom.dump(OS, nullptr);
else else
OS << "Error extracting the value"; OS << "Error extracting the value";
OS << "} "; OS << "} ";

View File

@ -29,8 +29,9 @@ class DWARFAcceleratorTable {
struct HeaderData { struct HeaderData {
typedef uint16_t AtomType; typedef uint16_t AtomType;
typedef uint16_t Form;
uint32_t DIEOffsetBase; uint32_t DIEOffsetBase;
SmallVector<std::pair<AtomType, DWARFFormValue>, 1> Atoms; SmallVector<std::pair<AtomType, Form>, 3> Atoms;
}; };
struct Header Hdr; struct Header Hdr;
@ -44,7 +45,7 @@ public:
: AccelSection(AccelSection), StringSection(StringSection), Relocs(Relocs) {} : AccelSection(AccelSection), StringSection(StringSection), Relocs(Relocs) {}
bool extract(); bool extract();
void dump(raw_ostream &OS); void dump(raw_ostream &OS) const;
}; };
} }