mirror of
https://github.com/amyinspace/MagicSetEditor2.git
synced 2026-06-10 04:57:00 -04:00
Catch all exceptions in onPaint functions, because otherwise we show a message box. Message boxes while in a paint handler lead to a crash on win32.
Made a CATCH_ALL_ERRORS macro containing the common catch statements. git-svn-id: svn://svn.code.sf.net/p/magicseteditor/code/trunk@1034 0fc631ac-6414-0410-93d0-97cfa31319b6
This commit is contained in:
@@ -87,7 +87,9 @@ void CardViewer::onPaint(wxPaintEvent&) {
|
||||
// draw
|
||||
if (!up_to_date) {
|
||||
up_to_date = true;
|
||||
draw(dc);
|
||||
try {
|
||||
draw(dc);
|
||||
} CATCH_ALL_ERRORS(false); // don't show message boxes in onPaint!
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -183,7 +183,9 @@ wxSize GalleryList::DoGetBestSize() const {
|
||||
|
||||
void GalleryList::onPaint(wxPaintEvent&) {
|
||||
wxBufferedPaintDC dc(this);
|
||||
OnDraw(dc);
|
||||
try {
|
||||
OnDraw(dc);
|
||||
} CATCH_ALL_ERRORS(false); // don't show message boxes in onPaint!
|
||||
}
|
||||
void GalleryList::OnDraw(DC& dc) {
|
||||
wxSize cs = GetClientSize();
|
||||
|
||||
@@ -985,16 +985,18 @@ size_t GraphControl::getDimensionality() const {
|
||||
|
||||
void GraphControl::onPaint(wxPaintEvent&) {
|
||||
wxBufferedPaintDC dc(this);
|
||||
wxSize cs = GetClientSize();
|
||||
RotatedDC rdc(dc, 0, RealRect(RealPoint(0,0),cs), 1, QUALITY_LOW);
|
||||
rdc.SetPen(*wxTRANSPARENT_PEN);
|
||||
rdc.SetBrush(wxSystemSettings::GetColour(wxSYS_COLOUR_WINDOW));
|
||||
rdc.DrawRectangle(rdc.getInternalRect());
|
||||
if (graph) {
|
||||
for (int layer = LAYER_BOTTOM ; layer < LAYER_COUNT ; ++layer) {
|
||||
graph->draw(rdc, current_item, (DrawLayer)layer);
|
||||
try {
|
||||
wxSize cs = GetClientSize();
|
||||
RotatedDC rdc(dc, 0, RealRect(RealPoint(0,0),cs), 1, QUALITY_LOW);
|
||||
rdc.SetPen(*wxTRANSPARENT_PEN);
|
||||
rdc.SetBrush(wxSystemSettings::GetColour(wxSYS_COLOUR_WINDOW));
|
||||
rdc.DrawRectangle(rdc.getInternalRect());
|
||||
if (graph) {
|
||||
for (int layer = LAYER_BOTTOM ; layer < LAYER_COUNT ; ++layer) {
|
||||
graph->draw(rdc, current_item, (DrawLayer)layer);
|
||||
}
|
||||
}
|
||||
}
|
||||
} CATCH_ALL_ERRORS(false); // don't show message boxes in onPaint!
|
||||
}
|
||||
|
||||
void GraphControl::onSize(wxSizeEvent&) {
|
||||
|
||||
@@ -115,6 +115,7 @@ class PackageInfoPanel : public wxPanel {
|
||||
DECLARE_EVENT_TABLE();
|
||||
|
||||
void onPaint(wxPaintEvent&);
|
||||
void draw(DC&);
|
||||
};
|
||||
|
||||
PackageInfoPanel::PackageInfoPanel(Window* parent)
|
||||
@@ -128,6 +129,11 @@ void PackageInfoPanel::setPackage(const InstallablePackageP& package) {
|
||||
|
||||
void PackageInfoPanel::onPaint(wxPaintEvent&) {
|
||||
wxBufferedPaintDC dc(this);
|
||||
try {
|
||||
draw(dc);
|
||||
} CATCH_ALL_ERRORS(false); // don't show message boxes in onPaint!
|
||||
}
|
||||
void PackageInfoPanel::draw(DC& dc) {
|
||||
wxSize cs = GetClientSize();
|
||||
dc.SetPen(*wxTRANSPARENT_PEN);
|
||||
dc.SetBrush(wxSystemSettings::GetColour(wxSYS_COLOUR_WINDOW));
|
||||
|
||||
@@ -200,7 +200,9 @@ void SymbolControl::draw(DC& dc) {
|
||||
}
|
||||
void SymbolControl::onPaint(wxPaintEvent&) {
|
||||
wxBufferedPaintDC dc(this);
|
||||
draw(dc);
|
||||
try {
|
||||
draw(dc);
|
||||
} CATCH_ALL_ERRORS(false); // don't show message boxes in onPaint!
|
||||
}
|
||||
|
||||
// ----------------------------------------------------------------------------- : Events
|
||||
|
||||
+3
-17
@@ -40,7 +40,7 @@ class MSE : public wxApp {
|
||||
*/
|
||||
int OnRun();
|
||||
/// On exit: write the settings to the config file
|
||||
int OnExit();
|
||||
int OnExit();
|
||||
/// On exception: display error message
|
||||
bool OnExceptionInMainLoop();
|
||||
};
|
||||
@@ -209,14 +209,7 @@ int MSE::OnRun() {
|
||||
(new WelcomeWindow())->Show();
|
||||
return wxApp::OnRun();
|
||||
|
||||
} catch (const Error& e) {
|
||||
handle_error(e, false);
|
||||
} catch (const 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!")), false);
|
||||
}
|
||||
} CATCH_ALL_ERRORS(true);
|
||||
return EXIT_FAILURE;
|
||||
}
|
||||
|
||||
@@ -234,13 +227,6 @@ int MSE::OnExit() {
|
||||
bool MSE::OnExceptionInMainLoop() {
|
||||
try {
|
||||
throw; // rethrow the exception, so we can examine it
|
||||
} catch (const Error& e) {
|
||||
handle_error(e, false);
|
||||
} catch (const 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!")), false);
|
||||
}
|
||||
} CATCH_ALL_ERRORS(true);
|
||||
return true;
|
||||
}
|
||||
|
||||
@@ -123,5 +123,17 @@ void handle_warning(const String& w, bool now = true);
|
||||
/** Should be called repeatedly (e.g. in an onIdle event handler) */
|
||||
void handle_pending_errors();
|
||||
|
||||
/// Catch all types of errors, and pass then to handle_error
|
||||
#define CATCH_ALL_ERRORS(handle_now) \
|
||||
catch (const Error& e) { \
|
||||
handle_error(e, false, handle_now); \
|
||||
} catch (const std::exception& e) { \
|
||||
/* we don't throw std::exception ourselfs, so this is probably something serious */ \
|
||||
String message(e.what(), IF_UNICODE(wxConvLocal, wxSTRING_MAXLEN) ); \
|
||||
handle_error(InternalError(message), false, handle_now); \
|
||||
} catch (...) { \
|
||||
handle_error(InternalError(_("An unexpected exception occurred!")), false, handle_now); \
|
||||
}
|
||||
|
||||
// ----------------------------------------------------------------------------- : EOF
|
||||
#endif
|
||||
|
||||
Reference in New Issue
Block a user