diff options
author | Rafael Espindola <rafael.espindola@gmail.com> | 2014-01-14 23:02:01 +0000 |
---|---|---|
committer | Rafael Espindola <rafael.espindola@gmail.com> | 2014-01-14 23:02:01 +0000 |
commit | 1d06f7208c993c1bc5c6ec578d2998721cf6513c (patch) | |
tree | ff919a25db9bcca2d083231643e4d7f96ea086c6 | |
parent | fd99af508d9f678ebd36d976b7ef23a05c0dc565 (diff) | |
download | bcm5719-llvm-1d06f7208c993c1bc5c6ec578d2998721cf6513c.tar.gz bcm5719-llvm-1d06f7208c993c1bc5c6ec578d2998721cf6513c.zip |
Use error_code in Module::materializeAll.
llvm-svn: 199269
-rw-r--r-- | llvm/include/llvm/IR/Module.h | 8 | ||||
-rw-r--r-- | llvm/lib/IR/Module.cpp | 16 |
2 files changed, 10 insertions, 14 deletions
diff --git a/llvm/include/llvm/IR/Module.h b/llvm/include/llvm/IR/Module.h index 822b8a45656..4bfa9e68aa8 100644 --- a/llvm/include/llvm/IR/Module.h +++ b/llvm/include/llvm/IR/Module.h @@ -22,6 +22,7 @@ #include "llvm/IR/Metadata.h" #include "llvm/Support/CBindingWrapping.h" #include "llvm/Support/DataTypes.h" +#include "llvm/Support/system_error.h" namespace llvm { @@ -450,11 +451,8 @@ public: /// materialized lazily. If !isDematerializable(), this method is a noop. void Dematerialize(GlobalValue *GV); - /// MaterializeAll - Make sure all GlobalValues in this Module are fully read. - /// If the module is corrupt, this returns true and fills in the optional - /// string with information about the problem. If successful, this returns - /// false. - bool MaterializeAll(std::string *ErrInfo = 0); + /// Make sure all GlobalValues in this Module are fully read. + error_code materializeAll(); /// MaterializeAllPermanently - Make sure all GlobalValues in this Module are /// fully read and clear the Materializer. If the module is corrupt, this diff --git a/llvm/lib/IR/Module.cpp b/llvm/lib/IR/Module.cpp index 996c5b67a41..06eea7e388a 100644 --- a/llvm/lib/IR/Module.cpp +++ b/llvm/lib/IR/Module.cpp @@ -377,20 +377,18 @@ void Module::Dematerialize(GlobalValue *GV) { return Materializer->Dematerialize(GV); } -bool Module::MaterializeAll(std::string *ErrInfo) { +error_code Module::materializeAll() { if (!Materializer) - return false; - error_code EC = Materializer->MaterializeModule(this); - if (!EC) - return false; - if (ErrInfo) - *ErrInfo = EC.message(); - return true; + return error_code::success(); + return Materializer->MaterializeModule(this); } bool Module::MaterializeAllPermanently(std::string *ErrInfo) { - if (MaterializeAll(ErrInfo)) + if (error_code EC = materializeAll()) { + if (ErrInfo) + *ErrInfo = EC.message(); return true; + } Materializer.reset(); return false; } |