diff options
author | Rafael Espindola <rafael.espindola@gmail.com> | 2014-06-23 22:00:37 +0000 |
---|---|---|
committer | Rafael Espindola <rafael.espindola@gmail.com> | 2014-06-23 22:00:37 +0000 |
commit | b138caba43b5c1a370bc9cf52d815c44bdf90159 (patch) | |
tree | 319bb84424a6ab56954abb3a004a2bf8c1b18b6b /include | |
parent | 20732d55c2fda872a32b2335febafa7327f8b066 (diff) | |
download | llvm-b138caba43b5c1a370bc9cf52d815c44bdf90159.tar.gz llvm-b138caba43b5c1a370bc9cf52d815c44bdf90159.tar.bz2 llvm-b138caba43b5c1a370bc9cf52d815c44bdf90159.tar.xz |
Pass a std::unique_ptr& to the create??? methods is lib/Object.
This makes the buffer ownership on error conditions very natural. The buffer
is only moved out of the argument if an object is constructed that now
owns the buffer.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@211546 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'include')
-rw-r--r-- | include/llvm/Object/Binary.h | 2 | ||||
-rw-r--r-- | include/llvm/Object/ObjectFile.h | 14 | ||||
-rw-r--r-- | include/llvm/Object/SymbolicFile.h | 9 |
3 files changed, 15 insertions, 10 deletions
diff --git a/include/llvm/Object/Binary.h b/include/llvm/Object/Binary.h index a87a006450..258a885d4f 100644 --- a/include/llvm/Object/Binary.h +++ b/include/llvm/Object/Binary.h @@ -128,7 +128,7 @@ public: /// @param Source The data to create the Binary from. Ownership is transferred /// to the Binary if successful. If an error is returned, /// Source is destroyed by createBinary before returning. -ErrorOr<Binary *> createBinary(MemoryBuffer *Source, +ErrorOr<Binary *> createBinary(std::unique_ptr<MemoryBuffer> &Source, LLVMContext *Context = nullptr); ErrorOr<Binary *> createBinary(StringRef Path); diff --git a/include/llvm/Object/ObjectFile.h b/include/llvm/Object/ObjectFile.h index 62c5b9b771..56799eb681 100644 --- a/include/llvm/Object/ObjectFile.h +++ b/include/llvm/Object/ObjectFile.h @@ -333,9 +333,11 @@ public: /// return true. /// @brief Create ObjectFile from path. static ErrorOr<ObjectFile *> createObjectFile(StringRef ObjectPath); - static ErrorOr<ObjectFile *> createObjectFile(MemoryBuffer *Object, - sys::fs::file_magic Type); - static ErrorOr<ObjectFile *> createObjectFile(MemoryBuffer *Object) { + static ErrorOr<ObjectFile *> + createObjectFile(std::unique_ptr<MemoryBuffer> &Object, + sys::fs::file_magic Type); + static ErrorOr<ObjectFile *> + createObjectFile(std::unique_ptr<MemoryBuffer> &Object) { return createObjectFile(Object, sys::fs::file_magic::unknown); } @@ -346,8 +348,10 @@ public: public: static ErrorOr<ObjectFile *> createCOFFObjectFile(MemoryBuffer *Object); - static ErrorOr<ObjectFile *> createELFObjectFile(MemoryBuffer *Object); - static ErrorOr<ObjectFile *> createMachOObjectFile(MemoryBuffer *Object); + static ErrorOr<ObjectFile *> + createELFObjectFile(std::unique_ptr<MemoryBuffer> &Object); + static ErrorOr<ObjectFile *> + createMachOObjectFile(std::unique_ptr<MemoryBuffer> &Object); }; // Inline function definitions. diff --git a/include/llvm/Object/SymbolicFile.h b/include/llvm/Object/SymbolicFile.h index 5c2d956d69..24908cde19 100644 --- a/include/llvm/Object/SymbolicFile.h +++ b/include/llvm/Object/SymbolicFile.h @@ -145,11 +145,12 @@ public: static ErrorOr<SymbolicFile *> createIRObjectFile(MemoryBuffer *Object, LLVMContext &Context); - static ErrorOr<SymbolicFile *> createSymbolicFile(MemoryBuffer *Object, - sys::fs::file_magic Type, - LLVMContext *Context); + static ErrorOr<SymbolicFile *> + createSymbolicFile(std::unique_ptr<MemoryBuffer> &Object, + sys::fs::file_magic Type, LLVMContext *Context); - static ErrorOr<SymbolicFile *> createSymbolicFile(MemoryBuffer *Object) { + static ErrorOr<SymbolicFile *> + createSymbolicFile(std::unique_ptr<MemoryBuffer> &Object) { return createSymbolicFile(Object, sys::fs::file_magic::unknown, nullptr); } static ErrorOr<SymbolicFile *> createSymbolicFile(StringRef ObjectPath); |