diff options
author | Rafael Espindola <rafael.espindola@gmail.com> | 2014-01-22 00:14:49 +0000 |
---|---|---|
committer | Rafael Espindola <rafael.espindola@gmail.com> | 2014-01-22 00:14:49 +0000 |
commit | 51cc360204c1a7037c9d1a03946c96702620499f (patch) | |
tree | 8a04b801ef6b996bc4b59f3ea35f406fd179fb25 /llvm/lib/Object/ObjectFile.cpp | |
parent | f52927fb1b3196574044159c9d398904903d1622 (diff) | |
download | llvm-51cc360204c1a7037c9d1a03946c96702620499f.zip llvm-51cc360204c1a7037c9d1a03946c96702620499f.tar.gz llvm-51cc360204c1a7037c9d1a03946c96702620499f.tar.bz2 |
Change createObjectFile to return an ErrorOr.
llvm-svn: 199776
Diffstat (limited to 'llvm/lib/Object/ObjectFile.cpp')
-rw-r--r-- | llvm/lib/Object/ObjectFile.cpp | 24 |
1 files changed, 10 insertions, 14 deletions
diff --git a/llvm/lib/Object/ObjectFile.cpp b/llvm/lib/Object/ObjectFile.cpp index 2397f4b..fd2b024 100644 --- a/llvm/lib/Object/ObjectFile.cpp +++ b/llvm/lib/Object/ObjectFile.cpp @@ -37,26 +37,22 @@ section_iterator ObjectFile::getRelocatedSection(DataRefImpl Sec) const { return section_iterator(SectionRef(Sec, this)); } -ObjectFile *ObjectFile::createObjectFile(MemoryBuffer *Object) { - if (Object->getBufferSize() < 64) { - delete Object; - return 0; - } - +ErrorOr<ObjectFile *> ObjectFile::createObjectFile(MemoryBuffer *Object) { + OwningPtr<MemoryBuffer> ScopedObj(Object); sys::fs::file_magic Type = sys::fs::identify_magic(Object->getBuffer()); + switch (Type) { case sys::fs::file_magic::unknown: case sys::fs::file_magic::bitcode: case sys::fs::file_magic::archive: case sys::fs::file_magic::macho_universal_binary: case sys::fs::file_magic::windows_resource: - delete Object; - return 0; + return object_error::invalid_file_type; case sys::fs::file_magic::elf_relocatable: case sys::fs::file_magic::elf_executable: case sys::fs::file_magic::elf_shared_object: case sys::fs::file_magic::elf_core: - return createELFObjectFile(Object).get(); + return createELFObjectFile(ScopedObj.take()); case sys::fs::file_magic::macho_object: case sys::fs::file_magic::macho_executable: case sys::fs::file_magic::macho_fixed_virtual_memory_shared_lib: @@ -67,18 +63,18 @@ ObjectFile *ObjectFile::createObjectFile(MemoryBuffer *Object) { case sys::fs::file_magic::macho_bundle: case sys::fs::file_magic::macho_dynamically_linked_shared_lib_stub: case sys::fs::file_magic::macho_dsym_companion: - return createMachOObjectFile(Object).get(); + return createMachOObjectFile(ScopedObj.take()); case sys::fs::file_magic::coff_object: case sys::fs::file_magic::coff_import_library: case sys::fs::file_magic::pecoff_executable: - return createCOFFObjectFile(Object).get(); + return createCOFFObjectFile(ScopedObj.take()); } llvm_unreachable("Unexpected Object File Type"); } -ObjectFile *ObjectFile::createObjectFile(StringRef ObjectPath) { +ErrorOr<ObjectFile *> ObjectFile::createObjectFile(StringRef ObjectPath) { OwningPtr<MemoryBuffer> File; - if (MemoryBuffer::getFile(ObjectPath, File)) - return NULL; + if (error_code EC = MemoryBuffer::getFile(ObjectPath, File)) + return EC; return createObjectFile(File.take()); } |