don't crash when restoring focus after showing a modal dialog
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@25294 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -167,18 +167,8 @@ void wxDialog::DoShowModal()
|
||||
|
||||
wxModalDialogs.Append(this);
|
||||
|
||||
wxWindow *parent = GetParent();
|
||||
wxWindow *parent = GetParent();
|
||||
|
||||
// remember where the focus was
|
||||
wxWindow *winFocus = FindFocus();
|
||||
if ( !winFocus )
|
||||
{
|
||||
winFocus = parent;
|
||||
}
|
||||
if ( !winFocus )
|
||||
{
|
||||
winFocus = wxTheApp->GetTopWindow();
|
||||
}
|
||||
#if TARGET_CARBON
|
||||
BeginAppModalStateForWindow( (WindowRef) MacGetWindowRef()) ;
|
||||
#else
|
||||
@@ -198,13 +188,6 @@ void wxDialog::DoShowModal()
|
||||
// TODO probably reenable the parent window if any
|
||||
s_macIsInModalLoop = formerModal ;
|
||||
#endif
|
||||
|
||||
|
||||
// and restore focus
|
||||
if ( winFocus )
|
||||
{
|
||||
winFocus->SetFocus();
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
@@ -167,18 +167,8 @@ void wxDialog::DoShowModal()
|
||||
|
||||
wxModalDialogs.Append(this);
|
||||
|
||||
wxWindow *parent = GetParent();
|
||||
wxWindow *parent = GetParent();
|
||||
|
||||
// remember where the focus was
|
||||
wxWindow *winFocus = FindFocus();
|
||||
if ( !winFocus )
|
||||
{
|
||||
winFocus = parent;
|
||||
}
|
||||
if ( !winFocus )
|
||||
{
|
||||
winFocus = wxTheApp->GetTopWindow();
|
||||
}
|
||||
#if TARGET_CARBON
|
||||
BeginAppModalStateForWindow( (WindowRef) MacGetWindowRef()) ;
|
||||
#else
|
||||
@@ -198,13 +188,6 @@ void wxDialog::DoShowModal()
|
||||
// TODO probably reenable the parent window if any
|
||||
s_macIsInModalLoop = formerModal ;
|
||||
#endif
|
||||
|
||||
|
||||
// and restore focus
|
||||
if ( winFocus )
|
||||
{
|
||||
winFocus->SetFocus();
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
Reference in New Issue
Block a user