diff options
author | Rafael Espindola <rafael.espindola@gmail.com> | 2015-02-03 00:49:57 +0000 |
---|---|---|
committer | Rafael Espindola <rafael.espindola@gmail.com> | 2015-02-03 00:49:57 +0000 |
commit | 3ee23a9ec85474100dd1fdaad9afa32118c4a590 (patch) | |
tree | d995e5b024e34a5d176aa4ebbc74f824e992a3c4 | |
parent | a6d38a326a60d18bc18ce5f01812118a031b8520 (diff) | |
download | bcm5719-llvm-3ee23a9ec85474100dd1fdaad9afa32118c4a590.tar.gz bcm5719-llvm-3ee23a9ec85474100dd1fdaad9afa32118c4a590.zip |
Use a non-fatal diag handler in the C API. FIxes PR22368.
llvm-svn: 227903
-rw-r--r-- | llvm/lib/Bitcode/Reader/BitReader.cpp | 13 | ||||
-rw-r--r-- | llvm/test/Bindings/llvm-c/Inputs/invalid.ll.bc | bin | 0 -> 332 bytes | |||
-rw-r--r-- | llvm/test/Bindings/llvm-c/invalid-bitcode.test | 3 |
3 files changed, 14 insertions, 2 deletions
diff --git a/llvm/lib/Bitcode/Reader/BitReader.cpp b/llvm/lib/Bitcode/Reader/BitReader.cpp index 9b3acb5ca0a..8641cd1487c 100644 --- a/llvm/lib/Bitcode/Reader/BitReader.cpp +++ b/llvm/lib/Bitcode/Reader/BitReader.cpp @@ -9,9 +9,11 @@ #include "llvm-c/BitReader.h" #include "llvm/Bitcode/ReaderWriter.h" +#include "llvm/IR/DiagnosticPrinter.h" #include "llvm/IR/LLVMContext.h" #include "llvm/IR/Module.h" #include "llvm/Support/MemoryBuffer.h" +#include "llvm/Support/raw_ostream.h" #include <cstring> #include <string> @@ -30,8 +32,15 @@ LLVMBool LLVMParseBitcodeInContext(LLVMContextRef ContextRef, LLVMMemoryBufferRef MemBuf, LLVMModuleRef *OutModule, char **OutMessage) { - ErrorOr<Module *> ModuleOrErr = - parseBitcodeFile(unwrap(MemBuf)->getMemBufferRef(), *unwrap(ContextRef)); + MemoryBufferRef Buf = unwrap(MemBuf)->getMemBufferRef(); + LLVMContext &Ctx = *unwrap(ContextRef); + + std::string Message; + raw_string_ostream Stream(Message); + DiagnosticPrinterRawOStream DP(Stream); + + ErrorOr<Module *> ModuleOrErr = parseBitcodeFile( + Buf, Ctx, [&](const DiagnosticInfo &DI) { DI.print(DP); }); if (std::error_code EC = ModuleOrErr.getError()) { if (OutMessage) *OutMessage = strdup(EC.message().c_str()); diff --git a/llvm/test/Bindings/llvm-c/Inputs/invalid.ll.bc b/llvm/test/Bindings/llvm-c/Inputs/invalid.ll.bc Binary files differnew file mode 100644 index 00000000000..a85c3644b3a --- /dev/null +++ b/llvm/test/Bindings/llvm-c/Inputs/invalid.ll.bc diff --git a/llvm/test/Bindings/llvm-c/invalid-bitcode.test b/llvm/test/Bindings/llvm-c/invalid-bitcode.test new file mode 100644 index 00000000000..997f7b5d5b7 --- /dev/null +++ b/llvm/test/Bindings/llvm-c/invalid-bitcode.test @@ -0,0 +1,3 @@ +; RUN: not llvm-c-test --module-dump < %S/Inputs/invalid.ll.bc 2>&1 | FileCheck %s + +CHECK: Error parsing bitcode: Corrupted bitcode |