summaryrefslogtreecommitdiff
path: root/lib/Object/MachOObjectFile.cpp
diff options
context:
space:
mode:
authorRafael Espindola <rafael.espindola@gmail.com>2013-04-07 20:01:29 +0000
committerRafael Espindola <rafael.espindola@gmail.com>2013-04-07 20:01:29 +0000
commit8764c8979c66966b5af62a0a316acead47c038cd (patch)
treebd622c0b2cae2135108c67457d9e404266bbe6ad /lib/Object/MachOObjectFile.cpp
parentf1cc8001fd405c3ec903cb6caf97a943bb3898ae (diff)
downloadllvm-8764c8979c66966b5af62a0a316acead47c038cd.tar.gz
llvm-8764c8979c66966b5af62a0a316acead47c038cd.tar.bz2
llvm-8764c8979c66966b5af62a0a316acead47c038cd.tar.xz
Make MachOObjectFile independent from MachOObject.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@178998 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Object/MachOObjectFile.cpp')
-rw-r--r--lib/Object/MachOObjectFile.cpp25
1 files changed, 9 insertions, 16 deletions
diff --git a/lib/Object/MachOObjectFile.cpp b/lib/Object/MachOObjectFile.cpp
index 75735418cb..4fe791c826 100644
--- a/lib/Object/MachOObjectFile.cpp
+++ b/lib/Object/MachOObjectFile.cpp
@@ -15,6 +15,7 @@
#include "llvm/Object/MachO.h"
#include "llvm/ADT/Triple.h"
#include "llvm/Object/MachOFormat.h"
+#include "llvm/Support/DataExtractor.h"
#include "llvm/Support/Format.h"
#include "llvm/Support/MemoryBuffer.h"
#include <cctype>
@@ -29,21 +30,6 @@ namespace object {
MachOObjectFile::MachOObjectFile(MemoryBuffer *Object, error_code &ec)
: ObjectFile(Binary::ID_MachO, Object) {
- // MachOObject takes ownership of the Buffer we passed to it, and
- // MachOObjectFile does, too, so we need to make sure they don't get the
- // same object. A MemoryBuffer is cheap (it's just a reference to memory,
- // not a copy of the memory itself), so just make a new copy here for
- // the MachOObjectFile.
- MemoryBuffer *NewBuffer =
- MemoryBuffer::getMemBuffer(Object->getBuffer(),
- Object->getBufferIdentifier(), false);
- std::string ErrorStr;
- MachOObj.reset(MachOObject::LoadFromBuffer(NewBuffer, &ErrorStr));
- if (!MachOObj) {
- ec = object_error::parse_failed;
- return;
- }
-
DataRefImpl DRI;
moveToNextSection(DRI);
uint32_t LoadCommandCount = getHeader()->NumLoadCommands;
@@ -78,7 +64,14 @@ MachOObjectFile::getLoadCommandInfo(unsigned Index) const {
void MachOObjectFile::ReadULEB128s(uint64_t Index,
SmallVectorImpl<uint64_t> &Out) const {
- return MachOObj->ReadULEB128s(Index, Out);
+ DataExtractor extractor(ObjectFile::getData(), true, 0);
+
+ uint32_t offset = Index;
+ uint64_t data = 0;
+ while (uint64_t delta = extractor.getULEB128(&offset)) {
+ data += delta;
+ Out.push_back(data);
+ }
}
const MachOFormat::Header *MachOObjectFile::getHeader() const {