summaryrefslogtreecommitdiffstats
path: root/llvm/lib/AsmParser/Parser.cpp
diff options
context:
space:
mode:
authorRafael Espindola <rafael.espindola@gmail.com>2014-08-19 22:05:47 +0000
committerRafael Espindola <rafael.espindola@gmail.com>2014-08-19 22:05:47 +0000
commit3f3d7acbcfbeca95c98360a9c5170961d0f7ca3f (patch)
tree763a4f85cbae9ab0f6fbddf1c10351e7ec18e880 /llvm/lib/AsmParser/Parser.cpp
parent96b02d1573895ec0dc71e1605d9b36e825c35987 (diff)
downloadbcm5719-llvm-3f3d7acbcfbeca95c98360a9c5170961d0f7ca3f.tar.gz
bcm5719-llvm-3f3d7acbcfbeca95c98360a9c5170961d0f7ca3f.zip
Split parseAssembly into parseAssembly and parseAssemblyInto.
This should restore the functionality of parsing new code into an existing module without the confusing interface. llvm-svn: 216031
Diffstat (limited to 'llvm/lib/AsmParser/Parser.cpp')
-rw-r--r--llvm/lib/AsmParser/Parser.cpp19
1 files changed, 13 insertions, 6 deletions
diff --git a/llvm/lib/AsmParser/Parser.cpp b/llvm/lib/AsmParser/Parser.cpp
index 7c6598106ec..9bc9b241666 100644
--- a/llvm/lib/AsmParser/Parser.cpp
+++ b/llvm/lib/AsmParser/Parser.cpp
@@ -21,17 +21,24 @@
#include <system_error>
using namespace llvm;
-std::unique_ptr<Module> llvm::parseAssembly(std::unique_ptr<MemoryBuffer> F,
- SMDiagnostic &Err,
- LLVMContext &Context) {
+bool llvm::parseAssemblyInto(std::unique_ptr<MemoryBuffer> F, Module &M,
+ SMDiagnostic &Err) {
SourceMgr SM;
- MemoryBuffer *Buf = F.get();
+ StringRef Buf = F->getBuffer();
SM.AddNewSourceBuffer(F.release(), SMLoc());
+ return LLParser(Buf, SM, Err, &M).Run();
+}
+
+std::unique_ptr<Module> llvm::parseAssembly(std::unique_ptr<MemoryBuffer> F,
+ SMDiagnostic &Err,
+ LLVMContext &Context) {
std::unique_ptr<Module> M =
- make_unique<Module>(Buf->getBufferIdentifier(), Context);
- if (LLParser(Buf->getBuffer(), SM, Err, M.get()).Run())
+ make_unique<Module>(F->getBufferIdentifier(), Context);
+
+ if (parseAssemblyInto(std::move(F), *M, Err))
return nullptr;
+
return std::move(M);
}
OpenPOWER on IntegriCloud