don't terminate the event loop in EndModal() if it was already terminated because of an exception thrown inside it (#9838)
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@55115 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -11,6 +11,8 @@
|
|||||||
#ifndef __GTKDIALOGH__
|
#ifndef __GTKDIALOGH__
|
||||||
#define __GTKDIALOGH__
|
#define __GTKDIALOGH__
|
||||||
|
|
||||||
|
class WXDLLIMPEXP_FWD_CORE wxGUIEventLoop;
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// wxDialog
|
// wxDialog
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
@@ -47,7 +49,7 @@ public:
|
|||||||
private:
|
private:
|
||||||
// common part of all ctors
|
// common part of all ctors
|
||||||
void Init();
|
void Init();
|
||||||
|
wxGUIEventLoop *m_modalLoop;
|
||||||
DECLARE_DYNAMIC_CLASS(wxDialog)
|
DECLARE_DYNAMIC_CLASS(wxDialog)
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@@ -18,11 +18,16 @@
|
|||||||
|
|
||||||
#include "wx/evtloop.h"
|
#include "wx/evtloop.h"
|
||||||
|
|
||||||
|
#include "wx/ptr_scpd.h"
|
||||||
|
|
||||||
#include <gtk/gtk.h>
|
#include <gtk/gtk.h>
|
||||||
|
|
||||||
// this is defined in src/gtk/toplevel.cpp
|
// this is defined in src/gtk/toplevel.cpp
|
||||||
extern int wxOpenModalDialogsCount;
|
extern int wxOpenModalDialogsCount;
|
||||||
|
|
||||||
|
wxDEFINE_TIED_SCOPED_PTR_TYPE(wxGUIEventLoop);
|
||||||
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// wxDialog
|
// wxDialog
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
@@ -31,6 +36,7 @@ IMPLEMENT_DYNAMIC_CLASS(wxDialog,wxTopLevelWindow)
|
|||||||
|
|
||||||
void wxDialog::Init()
|
void wxDialog::Init()
|
||||||
{
|
{
|
||||||
|
m_modalLoop = NULL;
|
||||||
m_returnCode = 0;
|
m_returnCode = 0;
|
||||||
m_modalShowing = false;
|
m_modalShowing = false;
|
||||||
m_themeEnabled = true;
|
m_themeEnabled = true;
|
||||||
@@ -130,7 +136,11 @@ int wxDialog::ShowModal()
|
|||||||
// NOTE: gtk_window_set_modal internally calls gtk_grab_add() !
|
// NOTE: gtk_window_set_modal internally calls gtk_grab_add() !
|
||||||
gtk_window_set_modal(GTK_WINDOW(m_widget), TRUE);
|
gtk_window_set_modal(GTK_WINDOW(m_widget), TRUE);
|
||||||
|
|
||||||
wxGUIEventLoop().Run();
|
// Run modal dialog event loop.
|
||||||
|
{
|
||||||
|
wxGUIEventLoopTiedPtr modal(&m_modalLoop, new wxGUIEventLoop());
|
||||||
|
m_modalLoop->Run();
|
||||||
|
}
|
||||||
|
|
||||||
gtk_window_set_modal(GTK_WINDOW(m_widget), FALSE);
|
gtk_window_set_modal(GTK_WINDOW(m_widget), FALSE);
|
||||||
|
|
||||||
@@ -151,7 +161,10 @@ void wxDialog::EndModal( int retCode )
|
|||||||
|
|
||||||
m_modalShowing = false;
|
m_modalShowing = false;
|
||||||
|
|
||||||
gtk_main_quit();
|
// Ensure Exit() is only called once. The dialog's event loop may be terminated
|
||||||
|
// externally due to an uncaught exception.
|
||||||
|
if (m_modalLoop && m_modalLoop->IsRunning())
|
||||||
|
m_modalLoop->Exit();
|
||||||
|
|
||||||
Show( false );
|
Show( false );
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user