Commit 98fcbbdd authored by twanvl's avatar twanvl

message boxes for errors

parent 9e911419
......@@ -34,6 +34,7 @@ IMPLEMENT_APP(MSE)
// ----------------------------------------------------------------------------- : Initialization
bool MSE::OnInit() {
try {
wxInitAllImageHandlers();
initFileFormats();
settings.read();
......@@ -41,6 +42,16 @@ bool MSE::OnInit() {
Window* wnd = new SetWindow(nullptr, new_shared1<Set>(Game::byName(_("magic"))));
wnd->Show();
return true;
} catch (Error e) {
handle_error(e, false);
} catch (std::exception e) {
// we don't throw std::exception ourselfs, so this is probably something serious
handle_error(InternalError(String(e.what(), IF_UNICODE(wxConvLocal, wxSTRING_MAXLEN) )), false);
} catch (...) {
handle_error(InternalError(_("An unexpected exception occurred, this is a bug!\nPlease save your work (use 'save as' to so you don't overwrite things),\n and restart Magic Set Editor.\n\nYou can leave a bug report on http://magicseteditor.sourceforge.net/")), false);
}
return false;
}
// ----------------------------------------------------------------------------- : Exit
......@@ -53,5 +64,15 @@ int MSE::OnExit() {
// ----------------------------------------------------------------------------- : Exception handling
bool MSE::OnExceptionInMainLoop() {
try {
throw; // rethrow the exception, so we can examine it
} catch (Error e) {
handle_error(e, false);
} catch (std::exception e) {
// we don't throw std::exception ourselfs, so this is probably something serious
handle_error(InternalError(String(e.what(), IF_UNICODE(wxConvLocal, wxSTRING_MAXLEN) )), false);
} catch (...) {
handle_error(InternalError(_("An unexpected exception occurred, this is a bug!\nPlease save your work (use 'save as' to so you don't overwrite things),\n and restart Magic Set Editor.\n\nYou can leave a bug report on http://magicseteditor.sourceforge.net/")), false);
}
return true;
}
......@@ -19,3 +19,31 @@ Error::~Error() {}
String Error::what() const {
return message;
}
// ----------------------------------------------------------------------------- : Error handling
// Errors for which a message box was already shown
vector<String> previous_errors;
String pending_error;
DECLARE_TYPEOF_COLLECTION(String);
void handle_error(const String& e, bool allow_duplicate = true, bool now = true) {
// Check duplicates
if (!allow_duplicate) {
FOR_EACH(pe, previous_errors) {
if (e == pe) return;
}
previous_errors.push_back(e);
}
// Only show errors in the main thread
if (!now || !wxThread::IsMain()) {
pending_error = e;
return;
}
// show message
wxMessageBox(e, _("Error"), wxOK | wxICON_ERROR);
}
void handle_error(const Error& e, bool allow_duplicate, bool now) {
handle_error(e.what(), allow_duplicate, now);
}
......@@ -80,5 +80,17 @@ class ScriptError : public Error {
inline ScriptError(const String& str) : Error(str) {}
};
// ----------------------------------------------------------------------------- : Error handling
/// Handle an error by showing a message box
/** If !allow_duplicate and the error is the same as the previous error, does nothing.
* If !now the error is handled by a later call to handle_pending_errors()
*/
void handle_error(const Error& e, bool allow_duplicate = true, bool now = true);
/// Handle errors that were not handled immediatly in handleError
/** Should be called repeatedly (e.g. in an onIdle event handler) */
void handle_pending_errors();
// ----------------------------------------------------------------------------- : EOF
#endif
......@@ -91,7 +91,7 @@ template <> void Reader::handle(String& s) {
// read all lines that are indented enough
readLine();
while (indent >= expected_indent) {
if (!first) value += '\n';
if (!first) multi_line_str += _('\n');
first = false;
multi_line_str += line.substr(expected_indent); // strip expected indent
readLine();
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment