reverted JS' rev. 1.27 - the real fix was 1.28, disabling recursion protection is not good idea

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@28424 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Václav Slavík
2004-07-23 16:44:46 +00:00
parent 7ef05b886f
commit 2e07bdda0a

View File

@@ -342,15 +342,8 @@ bool wxControlContainer::DoSetFocus()
wxLogTrace(_T("focus"), _T("SetFocus on wxPanel 0x%08lx."),
(unsigned long)m_winParent->GetHandle());
// FIXME: this recursion protection is needed for wxMac,
// but on Windows (at least), it breaks focus handling.
// This needs to be investigated further.
#ifdef __WXMAC__
if (m_inSetFocus)
return true;
#endif
m_inSetFocus = true;
// when the panel gets the focus we move the focus to either the last
// window that had the focus or the first one that can get it unless the
@@ -362,7 +355,6 @@ bool wxControlContainer::DoSetFocus()
if ( win == m_winParent )
{
// our child already has focus, don't take it away from it
m_inSetFocus = false;
return true;
}
@@ -376,6 +368,9 @@ bool wxControlContainer::DoSetFocus()
win = win->GetParent();
}
// protect against infinite recursion:
m_inSetFocus = true;
bool ret = SetFocusToChild();
m_inSetFocus = false;