aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRafael Espindola <rafael.espindola@gmail.com>2013-07-09 12:22:05 +0000
committerRafael Espindola <rafael.espindola@gmail.com>2013-07-09 12:22:05 +0000
commitc5f8757c727975e9a9d6247cc68fb79d7f4cff8f (patch)
tree7851ece1a9029e1367e60920d06a3cdbab3d5fee
parent12f45c3782c0d01bcf9973bbc23dba2b17ce54cb (diff)
downloadexternal_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.h10
-rw-r--r--lib/Object/Archive.cpp8
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;
}