From 03b7a1cf93b215ce99cd4eadfba3b08f3242a4db Mon Sep 17 00:00:00 2001 From: "Duncan P. N. Exon Smith" Date: Sun, 24 May 2015 16:33:33 +0000 Subject: AsmPrinter: Extract DwarfStringPoolEntry from DwarfStringPool, NFC Extract out `DwarfStringPoolEntry` and `DwarfStringPoolRef` from `DwarfStringPool` so that downstream users can start using `DwarfStringPool::getEntry()` directly. This will allow users to delay the decision between emitting a symbol or an offset until later. llvm-svn: 238116 --- llvm/lib/CodeGen/AsmPrinter/DwarfStringPool.cpp | 9 +++++---- llvm/lib/CodeGen/AsmPrinter/DwarfStringPool.h | 19 +++++++++---------- 2 files changed, 14 insertions(+), 14 deletions(-) (limited to 'llvm/lib/CodeGen') diff --git a/llvm/lib/CodeGen/AsmPrinter/DwarfStringPool.cpp b/llvm/lib/CodeGen/AsmPrinter/DwarfStringPool.cpp index a599126f0b7..9dd233a67ab 100644 --- a/llvm/lib/CodeGen/AsmPrinter/DwarfStringPool.cpp +++ b/llvm/lib/CodeGen/AsmPrinter/DwarfStringPool.cpp @@ -12,10 +12,11 @@ using namespace llvm; -DwarfStringPool::EntryTy &DwarfStringPool::getEntry(AsmPrinter &Asm, +DwarfStringPool::EntryRef DwarfStringPool::getEntry(AsmPrinter &Asm, StringRef Str) { - auto &Entry = Pool[Str]; - if (!Entry.Symbol) { + auto I = Pool.insert(std::make_pair(Str, EntryTy())); + if (I.second) { + auto &Entry = I.first->second; Entry.Index = Pool.size() - 1; Entry.Offset = NumBytes; Entry.Symbol = Asm.createTempSymbol(Prefix); @@ -23,7 +24,7 @@ DwarfStringPool::EntryTy &DwarfStringPool::getEntry(AsmPrinter &Asm, NumBytes += Str.size() + 1; assert(NumBytes > Entry.Offset && "Unexpected overflow"); } - return Entry; + return EntryRef(*I.first); } void DwarfStringPool::emit(AsmPrinter &Asm, MCSection *StrSection, diff --git a/llvm/lib/CodeGen/AsmPrinter/DwarfStringPool.h b/llvm/lib/CodeGen/AsmPrinter/DwarfStringPool.h index 77b6ffaa9f1..28c73033a5c 100644 --- a/llvm/lib/CodeGen/AsmPrinter/DwarfStringPool.h +++ b/llvm/lib/CodeGen/AsmPrinter/DwarfStringPool.h @@ -12,6 +12,7 @@ #include "llvm/ADT/StringMap.h" #include "llvm/CodeGen/AsmPrinter.h" +#include "llvm/CodeGen/DwarfStringPoolEntry.h" #include "llvm/Support/Allocator.h" #include @@ -25,16 +26,14 @@ class StringRef; // A String->Symbol mapping of strings used by indirect // references. class DwarfStringPool { - struct EntryTy { - MCSymbol *Symbol; - unsigned Offset; - unsigned Index; - }; + typedef DwarfStringPoolEntry EntryTy; StringMap Pool; StringRef Prefix; unsigned NumBytes = 0; public: + typedef DwarfStringPoolEntryRef EntryRef; + DwarfStringPool(BumpPtrAllocator &A, AsmPrinter &Asm, StringRef Prefix) : Pool(A), Prefix(Prefix) {} @@ -44,24 +43,24 @@ public: /// \brief Returns an entry into the string pool with the given /// string text. MCSymbol *getSymbol(AsmPrinter &Asm, StringRef Str) { - return getEntry(Asm, Str).Symbol; + return getEntry(Asm, Str).getSymbol(); } /// Get a byte offset into the string pool with the given text. unsigned getOffset(AsmPrinter &Asm, StringRef Str) { - return getEntry(Asm, Str).Offset; + return getEntry(Asm, Str).getOffset(); } /// \brief Returns the index into the string pool with the given /// string text. unsigned getIndex(AsmPrinter &Asm, StringRef Str) { - return getEntry(Asm, Str).Index; + return getEntry(Asm, Str).getIndex(); } bool empty() const { return Pool.empty(); } -private: - EntryTy &getEntry(AsmPrinter &Asm, StringRef Str); + /// Get a reference to an entry in the string pool. + EntryRef getEntry(AsmPrinter &Asm, StringRef Str); }; } #endif -- cgit v1.2.3