Change the verifier to never throw an exception. Instead verifyModule canoptionally return the string error, which is an easier api for clients touse anyway.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@29017 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Chris Lattner 2006-07-06 18:02:27 +00:00
parent 1d662a6afc
commit 05ac92ca7d
5 changed files with 41 additions and 63 deletions

View File

@ -118,13 +118,11 @@ public:
double(bca.numFunctions);
if (bca.progressiveVerify) {
try {
verifyModule(*M, ThrowExceptionAction);
} catch ( std::string& msg ) {
std::string msg;
if (verifyModule(*M, ReturnStatusAction, &msg))
bca.VerifyInfo += "Verify@Finish: " + msg + "\n";
}
}
}
virtual void handleModuleBegin(const std::string& id) {
if (os)
@ -136,13 +134,11 @@ public:
if (os)
*os << " } End Module " << id << "\n";
if (bca.progressiveVerify) {
try {
verifyModule(*M, ThrowExceptionAction);
} catch ( std::string& msg ) {
std::string msg;
if (verifyModule(*M, ReturnStatusAction, &msg))
bca.VerifyInfo += "Verify@EndModule: " + msg + "\n";
}
}
}
virtual void handleVersionInfo(
unsigned char RevisionNum, ///< Byte code revision number
@ -233,13 +229,11 @@ public:
if (os)
*os << " } END BLOCK: ModuleGlobalInfo\n";
if (bca.progressiveVerify) {
try {
verifyModule(*M, ThrowExceptionAction);
} catch ( std::string& msg ) {
std::string msg;
if (verifyModule(*M, ReturnStatusAction, &msg))
bca.VerifyInfo += "Verify@EndModuleGlobalInfo: " + msg + "\n";
}
}
}
virtual void handleCompactionTableBegin() {
if (os)
@ -347,13 +341,11 @@ public:
double(currFunc->numInstructions);
if (bca.progressiveVerify) {
try {
verifyModule(*M, ThrowExceptionAction);
} catch ( std::string& msg ) {
std::string msg;
if (verifyModule(*M, ReturnStatusAction, &msg))
bca.VerifyInfo += "Verify@EndFunction: " + msg + "\n";
}
}
}
virtual void handleBasicBlockBegin( unsigned blocknum) {
if (os)
@ -523,13 +515,11 @@ public:
*os << " } END BLOCK: GlobalConstants\n";
if (bca.progressiveVerify) {
try {
verifyModule(*M, ThrowExceptionAction);
} catch ( std::string& msg ) {
std::string msg;
if (verifyModule(*M, ReturnStatusAction, &msg))
bca.VerifyInfo += "Verify@EndGlobalConstants: " + msg + "\n";
}
}
}
virtual void handleAlignment(unsigned numBytes) {
bca.numAlignment += numBytes;

View File

@ -152,18 +152,13 @@ namespace { // Anonymous namespace for class
/// this condition, do so.
///
void abortIfBroken() {
if (Broken)
{
if (Broken) {
msgs << "Broken module found, ";
switch (action)
{
switch (action) {
case AbortProcessAction:
msgs << "compilation aborted!\n";
std::cerr << msgs.str();
abort();
case ThrowExceptionAction:
msgs << "verification terminated.\n";
throw msgs.str();
case PrintMessageAction:
msgs << "verification continues.\n";
std::cerr << msgs.str();
@ -799,11 +794,15 @@ bool llvm::verifyFunction(const Function &f, VerifierFailureAction action) {
/// verifyModule - Check a module for errors, printing messages on stderr.
/// Return true if the module is corrupt.
///
bool llvm::verifyModule(const Module &M, VerifierFailureAction action) {
bool llvm::verifyModule(const Module &M, VerifierFailureAction action,
std::string *ErrorInfo) {
PassManager PM;
Verifier *V = new Verifier(action);
PM.add(V);
PM.run((Module&)M);
if (ErrorInfo && V->Broken)
*ErrorInfo = V->msgs.str();
return V->Broken;
}

View File

@ -63,15 +63,15 @@ int main(int argc, char **argv) {
return 1;
}
try {
if (!DisableVerify)
verifyModule(*M.get(), ThrowExceptionAction);
} catch (const std::string &Err) {
if (!DisableVerify) {
std::string Err;
if (verifyModule(*M.get(), ReturnStatusAction, &Err)) {
std::cerr << argv[0]
<< ": assembly parsed, but does not verify as correct!\n";
std::cerr << Err;
return 1;
}
}
if (DumpAsm) std::cerr << "Here's the assembly:\n" << *M.get();

View File

@ -73,23 +73,10 @@ main(int argc, char **argv) {
if ( M && Verify ) {
std::string verificationMsg;
try {
verifyModule( *M, ThrowExceptionAction );
} catch (std::string& errmsg ) {
verificationMsg = errmsg;
}
if ( verificationMsg.length() > 0 )
if (verifyModule(*M, ReturnStatusAction, &verificationMsg))
std::cerr << "Final Verification Message: " << verificationMsg << "\n";
}
// If there was an error, print it and stop.
if ( ErrorMessage.size() ) {
std::cerr << argv[0] << ": " << ErrorMessage << "\n";
return 1;
}
if (Out != &std::cout) {
((std::ofstream*)Out)->close();
delete Out;

View File

@ -59,15 +59,17 @@ int main(int argc, char **argv) {
return 1;
}
try {
if (!DisableVerify)
verifyModule(*M.get(), ThrowExceptionAction);
} catch (const std::string &Err) {
// FIXME: llvm2cpp should read .bc files and thus not run the verifier
// explicitly!
if (!DisableVerify) {
std::string Err;
if (verifyModule(*M.get(), ReturnStatusAction, &Err)) {
std::cerr << argv[0]
<< ": assembly parsed, but does not verify as correct!\n";
std::cerr << Err;
return 1;
}
}
if (OutputFilename != "") { // Specified an output filename?
if (OutputFilename != "-") { // Not stdout?