Extract the call to wxWindow::SetCanFocus() into a separate
UpdateParentCanFocus() function as it can be necessary to do it from places
other than UpdateCanFocusChildren() too.
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@74582
c3d73ce0-8a6f-49c7-b76d-
6d57e0e08775
wxWindow *m_winLastFocused;
private:
wxWindow *m_winLastFocused;
private:
+ // Update the window status to reflect whether it is getting focus or not.
+ void UpdateParentCanFocus();
+
// Indicates whether the associated window can ever have focus itself.
//
// Usually this is the case, e.g. a wxPanel can be used either as a
// Indicates whether the associated window can ever have focus itself.
//
// Usually this is the case, e.g. a wxPanel can be used either as a
// wxControlContainerBase
// ----------------------------------------------------------------------------
// wxControlContainerBase
// ----------------------------------------------------------------------------
+void wxControlContainerBase::UpdateParentCanFocus()
+{
+ // In the ports where it does something non trivial, the parent window
+ // should only be focusable if it doesn't have any focusable children
+ // (e.g. native focus handling in wxGTK totally breaks down otherwise).
+ m_winParent->SetCanFocus(m_acceptsFocusSelf && !m_acceptsFocusChildren);
+}
+
bool wxControlContainerBase::UpdateCanFocusChildren()
{
const bool acceptsFocusChildren = HasAnyFocusableChildren();
bool wxControlContainerBase::UpdateCanFocusChildren()
{
const bool acceptsFocusChildren = HasAnyFocusableChildren();
{
m_acceptsFocusChildren = acceptsFocusChildren;
{
m_acceptsFocusChildren = acceptsFocusChildren;
- // In the ports where it does something non trivial, the parent window
- // should only be focusable if it doesn't have any focusable children
- // (e.g. native focus handling in wxGTK totally breaks down otherwise).
- m_winParent->SetCanFocus(m_acceptsFocusSelf && !m_acceptsFocusChildren);
+ UpdateParentCanFocus();
}
return m_acceptsFocusChildren;
}
return m_acceptsFocusChildren;