diff options
author | Rafael Espindola <rafael.espindola@gmail.com> | 2014-09-03 17:31:46 +0000 |
---|---|---|
committer | Rafael Espindola <rafael.espindola@gmail.com> | 2014-09-03 17:31:46 +0000 |
commit | 688121571ae35f2f767ae16aa84c8df4a889ab72 (patch) | |
tree | 7e3e176b69634344a4474262d04550eee100b48c /llvm/lib/Bitcode/Reader | |
parent | 99b96f42d6d3609d706fb38a85abee2e7127d304 (diff) | |
download | bcm5719-llvm-688121571ae35f2f767ae16aa84c8df4a889ab72.tar.gz bcm5719-llvm-688121571ae35f2f767ae16aa84c8df4a889ab72.zip |
Pass a && to getLazyBitcodeModule.
This forces callers to use std::move when calling it. It is somewhat odd to have
code with std::move that doesn't always move, but it is also odd to have code
without std::move that sometimes moves.
llvm-svn: 217049
Diffstat (limited to 'llvm/lib/Bitcode/Reader')
-rw-r--r-- | llvm/lib/Bitcode/Reader/BitReader.cpp | 2 | ||||
-rw-r--r-- | llvm/lib/Bitcode/Reader/BitcodeReader.cpp | 9 |
2 files changed, 6 insertions, 5 deletions
diff --git a/llvm/lib/Bitcode/Reader/BitReader.cpp b/llvm/lib/Bitcode/Reader/BitReader.cpp index 76a7e6ae159..9b3acb5ca0a 100644 --- a/llvm/lib/Bitcode/Reader/BitReader.cpp +++ b/llvm/lib/Bitcode/Reader/BitReader.cpp @@ -54,7 +54,7 @@ LLVMBool LLVMGetBitcodeModuleInContext(LLVMContextRef ContextRef, std::unique_ptr<MemoryBuffer> Owner(unwrap(MemBuf)); ErrorOr<Module *> ModuleOrErr = - getLazyBitcodeModule(Owner, *unwrap(ContextRef)); + getLazyBitcodeModule(std::move(Owner), *unwrap(ContextRef)); Owner.release(); if (std::error_code EC = ModuleOrErr.getError()) { diff --git a/llvm/lib/Bitcode/Reader/BitcodeReader.cpp b/llvm/lib/Bitcode/Reader/BitcodeReader.cpp index a614ec37cf6..84ee0b4b3a6 100644 --- a/llvm/lib/Bitcode/Reader/BitcodeReader.cpp +++ b/llvm/lib/Bitcode/Reader/BitcodeReader.cpp @@ -3520,7 +3520,7 @@ const std::error_category &llvm::BitcodeErrorCategory() { /// \param[in] WillMaterializeAll Set to \c true if the caller promises to /// materialize everything -- in particular, if this isn't truly lazy. static ErrorOr<Module *> -getLazyBitcodeModuleImpl(std::unique_ptr<MemoryBuffer> &Buffer, +getLazyBitcodeModuleImpl(std::unique_ptr<MemoryBuffer> &&Buffer, LLVMContext &Context, bool WillMaterializeAll) { Module *M = new Module(Buffer->getBufferIdentifier(), Context); BitcodeReader *R = new BitcodeReader(Buffer.get(), Context); @@ -3545,9 +3545,9 @@ getLazyBitcodeModuleImpl(std::unique_ptr<MemoryBuffer> &Buffer, } ErrorOr<Module *> -llvm::getLazyBitcodeModule(std::unique_ptr<MemoryBuffer> &Buffer, +llvm::getLazyBitcodeModule(std::unique_ptr<MemoryBuffer> &&Buffer, LLVMContext &Context) { - return getLazyBitcodeModuleImpl(Buffer, Context, false); + return getLazyBitcodeModuleImpl(std::move(Buffer), Context, false); } Module *llvm::getStreamedBitcodeModule(const std::string &name, @@ -3569,7 +3569,8 @@ Module *llvm::getStreamedBitcodeModule(const std::string &name, ErrorOr<Module *> llvm::parseBitcodeFile(MemoryBufferRef Buffer, LLVMContext &Context) { std::unique_ptr<MemoryBuffer> Buf = MemoryBuffer::getMemBuffer(Buffer, false); - ErrorOr<Module *> ModuleOrErr = getLazyBitcodeModuleImpl(Buf, Context, true); + ErrorOr<Module *> ModuleOrErr = + getLazyBitcodeModuleImpl(std::move(Buf), Context, true); if (!ModuleOrErr) return ModuleOrErr; Module *M = ModuleOrErr.get(); |