diff options
author | Rafael Espindola <rafael.espindola@gmail.com> | 2013-07-09 12:22:05 +0000 |
---|---|---|
committer | Rafael Espindola <rafael.espindola@gmail.com> | 2013-07-09 12:22:05 +0000 |
commit | c5f8757c727975e9a9d6247cc68fb79d7f4cff8f (patch) | |
tree | 7851ece1a9029e1367e60920d06a3cdbab3d5fee | |
parent | 12f45c3782c0d01bcf9973bbc23dba2b17ce54cb (diff) | |
download | external_llvm-c5f8757c727975e9a9d6247cc68fb79d7f4cff8f.zip external_llvm-c5f8757c727975e9a9d6247cc68fb79d7f4cff8f.tar.gz external_llvm-c5f8757c727975e9a9d6247cc68fb79d7f4cff8f.tar.bz2 |
Add getHeader helper and move ToHeader to the cpp file.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@185933 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | include/llvm/Object/Archive.h | 10 | ||||
-rw-r--r-- | lib/Object/Archive.cpp | 8 |
2 files changed, 11 insertions, 7 deletions
diff --git a/include/llvm/Object/Archive.h b/include/llvm/Object/Archive.h index aac978c..0cd1867 100644 --- a/include/llvm/Object/Archive.h +++ b/include/llvm/Object/Archive.h @@ -36,10 +36,6 @@ struct ArchiveMemberHeader { uint64_t getSize() const; }; -static const ArchiveMemberHeader *ToHeader(const char *base) { - return reinterpret_cast<const ArchiveMemberHeader *>(base); -} - class Archive : public Binary { virtual void anchor(); public: @@ -50,6 +46,10 @@ public: /// \brief Offset from Data to the start of the file. uint16_t StartOfFile; + const ArchiveMemberHeader *getHeader() const { + return reinterpret_cast<const ArchiveMemberHeader *>(Data.data()); + } + public: Child(const Archive *Parent, const char *Start); @@ -64,7 +64,7 @@ public: Child getNext() const; error_code getName(StringRef &Result) const; - StringRef getRawName() const { return ToHeader(Data.data())->getName(); } + StringRef getRawName() const { return getHeader()->getName(); } /// \return the size of the archive member without the header or padding. uint64_t getSize() const { return Data.size() - StartOfFile; } diff --git a/lib/Object/Archive.cpp b/lib/Object/Archive.cpp index c8a9692..14b21fd 100644 --- a/lib/Object/Archive.cpp +++ b/lib/Object/Archive.cpp @@ -61,12 +61,16 @@ uint64_t ArchiveMemberHeader::getSize() const { return ret; } +static const ArchiveMemberHeader *toHeader(const char *base) { + return reinterpret_cast<const ArchiveMemberHeader *>(base); +} + Archive::Child::Child(const Archive *Parent, const char *Start) : Parent(Parent) { if (!Start) return; - const ArchiveMemberHeader *Header = ToHeader(Start); + const ArchiveMemberHeader *Header = toHeader(Start); Data = StringRef(Start, sizeof(ArchiveMemberHeader) + Header->getSize()); // Setup StartOfFile and PaddingBytes. @@ -270,7 +274,7 @@ Archive::child_iterator Archive::begin_children(bool skip_internal) const { const char *Loc = Data->getBufferStart() + strlen(Magic); Child c(this, Loc); // Skip internals at the beginning of an archive. - if (skip_internal && isInternalMember(*ToHeader(Loc))) + if (skip_internal && isInternalMember(*toHeader(Loc))) return c.getNext(); return c; } |