aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorWladimir J. van der Laan <laanwj@gmail.com>2012-04-15 09:22:26 -0700
committerWladimir J. van der Laan <laanwj@gmail.com>2012-04-15 09:22:26 -0700
commit9ea8e60a0c8531e647521531d4b0fed757abc331 (patch)
tree7d1d5e39091be54d23f8dd2bf1a1f5a0cf73a08f
parentc99ddfaa22abd23781c81819d851df8e866b6725 (diff)
parenta7a0c7a1bf3461bd43aacaf03ee5015903ead168 (diff)
Merge pull request #1097 from laanwj/2012_04_runawayexception
Show a message box when runaway exception happens
-rw-r--r--src/qt/bitcoin.cpp13
1 files changed, 11 insertions, 2 deletions
diff --git a/src/qt/bitcoin.cpp b/src/qt/bitcoin.cpp
index bfb49cbcab..463b2cfa79 100644
--- a/src/qt/bitcoin.cpp
+++ b/src/qt/bitcoin.cpp
@@ -119,6 +119,15 @@ std::string _(const char* psz)
return QCoreApplication::translate("bitcoin-core", psz).toStdString();
}
+/* Handle runaway exceptions. Shows a message box with the problem and quits the program.
+ */
+static void handleRunawayException(std::exception *e)
+{
+ PrintExceptionContinue(e, "Runaway exception");
+ QMessageBox::critical(0, "Runaway exception", BitcoinGUI::tr("A fatal error occured. Bitcoin can no longer continue safely and will quit.") + QString("\n\n") + QString::fromStdString(strMiscWarning));
+ exit(1);
+}
+
#ifdef WIN32
#define strncasecmp strnicmp
#endif
@@ -284,9 +293,9 @@ int main(int argc, char *argv[])
return 1;
}
} catch (std::exception& e) {
- PrintException(&e, "Runaway exception");
+ handleRunawayException(&e);
} catch (...) {
- PrintException(NULL, "Runaway exception");
+ handleRunawayException(NULL);
}
return 0;
}