git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@11692
c3d73ce0-8a6f-49c7-b76d-
6d57e0e08775
{
if ( node != m_nodeCurrent )
{
{
if ( node != m_nodeCurrent )
{
+ wxMenuItemList::Node *nodeOldCurrent = m_nodeCurrent;
+
+ m_nodeCurrent = node;
+
+ if ( nodeOldCurrent )
- wxMenuItem *item = m_nodeCurrent->GetData();
+ wxMenuItem *item = nodeOldCurrent->GetData();
wxCHECK_RET( item, _T("no current item?") );
// if it was the currently opened menu, close it
wxCHECK_RET( item, _T("no current item?") );
// if it was the currently opened menu, close it
- m_nodeCurrent = node;
-
if ( m_nodeCurrent )
RefreshItem(m_nodeCurrent->GetData());
}
if ( m_nodeCurrent )
RefreshItem(m_nodeCurrent->GetData());
}
{
wxCHECK_RET( pos < GetCount(), _T("invalid menu index in DoSelectMenu") );
{
wxCHECK_RET( pos < GetCount(), _T("invalid menu index in DoSelectMenu") );
+ int posOld = m_current;
+
+ m_current = pos;
+
+ if ( posOld != -1 )
{
// close the previous menu
if ( IsShowingMenu() )
{
// close the previous menu
if ( IsShowingMenu() )
m_shouldShowMenu = old;
}
m_shouldShowMenu = old;
}
- RefreshItem((size_t)m_current);
+ RefreshItem((size_t)posOld);
void wxMenuBar::OnKeyDown(wxKeyEvent& event)
{
void wxMenuBar::OnKeyDown(wxKeyEvent& event)
{
- // the current item must have been set before
- wxCHECK_RET( m_current != -1, _T("where is current item?") );
+ // ensure that we have a current item - we might not have it if we're
+ // given the focus with Alt or F10 press (and under GTK+ the menubar
+ // somehow gets the keyboard events even when it doesn't have focus...)
+ if ( m_current == -1 )
+ {
+ if ( !HasCapture() )
+ {
+ SelectMenu(0);
+ }
+ else // we do have capture
+ {
+ // we always maintain a valid current item while we're in modal
+ // state (i.e. have the capture)
+ wxFAIL_MSG( _T("how did we manage to lose current item?") );
+
+ return;
+ }
+ }
int key = event.GetKeyCode();
int key = event.GetKeyCode();
// item, not to the right of it
wxRect rectItem = GetItemRect(m_current);
// item, not to the right of it
wxRect rectItem = GetItemRect(m_current);
- // Release mouse, because the menu will get the capture.
- if (HasCapture())
- ReleaseMouse();
-
m_menuShown->Popup(ClientToScreen(rectItem.GetPosition()),
wxSize(0, rectItem.GetHeight()),
selectFirst);
m_menuShown->Popup(ClientToScreen(rectItem.GetPosition()),
wxSize(0, rectItem.GetHeight()),
selectFirst);
- RefreshItem((size_t)m_current);
-
+ size_t current = m_current;
+
+ RefreshItem(current);
void wxWindow::CaptureMouse()
{
void wxWindow::CaptureMouse()
{
+ wxLogTrace(_T("mousecapture"), _T("CaptureMouse(0x%08x)"), this);
+
wxWindow *winOld = GetCapture();
if ( winOld )
{
wxWindow *winOld = GetCapture();
if ( winOld )
{
delete item;
}
//else: stack is empty, no previous capture
delete item;
}
//else: stack is empty, no previous capture
+
+ wxLogTrace(_T("mousecapture"),
+ _T("After ReleaseMouse() mouse is captured by 0x%08x"),
+ GetCapture());
}
// ----------------------------------------------------------------------------
}
// ----------------------------------------------------------------------------