about summary refs log tree commit diff homepage
path: root/lib/Module
diff options
context:
space:
mode:
authorJiri Slaby <jirislaby@gmail.com>2018-06-15 08:28:22 +0200
committerMartinNowack <martin.nowack@gmail.com>2018-07-12 23:25:49 +0100
commit9968c00bdd7626249b6bd3f4df3f00da7406b0c1 (patch)
tree60b5a35cb3e5fd08ebf28cdd2d927164a3a9b3d2 /lib/Module
parent4c0c9719678d6a3a7f3cbb7ea6f513bef57180bf (diff)
downloadklee-9968c00bdd7626249b6bd3f4df3f00da7406b0c1.tar.gz
llvm38: archive child iterator changes
After LLVM commit 25569fdcdab0, archive iterator returns
object::Archive::Child instead of child_iterator, adapt to that.

Signed-off-by: Jiri Slaby <jirislaby@gmail.com>
Diffstat (limited to 'lib/Module')
-rw-r--r--lib/Module/ModuleUtil.cpp19
1 files changed, 15 insertions, 4 deletions
diff --git a/lib/Module/ModuleUtil.cpp b/lib/Module/ModuleUtil.cpp
index 37c957ba..4912ca94 100644
--- a/lib/Module/ModuleUtil.cpp
+++ b/lib/Module/ModuleUtil.cpp
@@ -424,8 +424,19 @@ bool klee::loadFile(const std::string &fileName, LLVMContext &context,
 
         StringRef memberName;
 #if LLVM_VERSION_CODE >= LLVM_VERSION(3, 5)
-        ErrorOr<StringRef> memberNameErr = AI->getName();
-        std::error_code ec = memberNameErr.getError();
+        std::error_code ec;
+#if LLVM_VERSION_CODE >= LLVM_VERSION(3, 8)
+        ErrorOr<object::Archive::Child> childOrErr = *AI;
+        ec = childOrErr.getError();
+        if (ec) {
+                errorMsg = ec.message();
+                return false;
+        }
+#else
+	object::Archive::child_iterator childOrErr = AI;
+#endif
+        ErrorOr<StringRef> memberNameErr = childOrErr->getName();
+        ec = memberNameErr.getError();
         if (!ec) {
           memberName = memberNameErr.get();
 #else
@@ -443,7 +454,7 @@ bool klee::loadFile(const std::string &fileName, LLVMContext &context,
 
 #if LLVM_VERSION_CODE >= LLVM_VERSION(3, 5)
         ErrorOr<std::unique_ptr<llvm::object::Binary>> child =
-            AI->getAsBinary();
+            childOrErr->getAsBinary();
         ec = child.getError();
 #else
         OwningPtr<object::Binary> child;
@@ -452,7 +463,7 @@ bool klee::loadFile(const std::string &fileName, LLVMContext &context,
         if (ec) {
 // If we can't open as a binary object file its hopefully a bitcode file
 #if LLVM_VERSION_CODE >= LLVM_VERSION(3, 6)
-          ErrorOr<MemoryBufferRef> buff = AI->getMemoryBufferRef();
+          ErrorOr<MemoryBufferRef> buff = childOrErr->getMemoryBufferRef();
           ec = buff.getError();
 #elif LLVM_VERSION_CODE >= LLVM_VERSION(3, 5)
           ErrorOr<std::unique_ptr<MemoryBuffer>> buffErr =