From c1dd282b9b2ae7879d2a6aa58d1a1bac1453ee4e Mon Sep 17 00:00:00 2001 From: Stefano Ceccherini Date: Sun, 28 May 2006 08:50:52 +0000 Subject: [PATCH] Fixed some bugs in StealFocus, RemoveFocus and SetStickyMode git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@17614 a95241bf-73f2-0310-859d-f6bbb57e9c96 --- src/kits/interface/Menu.cpp | 20 +++++++++++--------- src/kits/interface/MenuBar.cpp | 12 ++++++++---- 2 files changed, 19 insertions(+), 13 deletions(-) diff --git a/src/kits/interface/Menu.cpp b/src/kits/interface/Menu.cpp index a5cf6edfb6..e860dc2b37 100644 --- a/src/kits/interface/Menu.cpp +++ b/src/kits/interface/Menu.cpp @@ -1931,15 +1931,17 @@ BMenu::SetIgnoreHidden(bool on) void BMenu::SetStickyMode(bool on) { - fStickyMode = on; - - // TODO: Ugly hack, but it needs to be done right here in this method - BMenuBar *menuBar = dynamic_cast(this); - if (on && menuBar != NULL && menuBar->LockLooper()) { - // Steal the focus from the current focus view - // (needed to handle keyboard navigation) - menuBar->StealFocus(); - menuBar->UnlockLooper(); + if (fStickyMode != on) { + // TODO: Ugly hack, but it needs to be done right here in this method + BMenuBar *menuBar = dynamic_cast(this); + if (on && menuBar != NULL && menuBar->LockLooper()) { + // Steal the focus from the current focus view + // (needed to handle keyboard navigation) + menuBar->StealFocus(); + menuBar->UnlockLooper(); + } + + fStickyMode = on; } // If we are switching to sticky mode, propagate the status diff --git a/src/kits/interface/MenuBar.cpp b/src/kits/interface/MenuBar.cpp index abe0d69211..b0103d754a 100644 --- a/src/kits/interface/MenuBar.cpp +++ b/src/kits/interface/MenuBar.cpp @@ -17,6 +17,7 @@ #include #include +using BPrivate::gDefaultTokens; struct menubar_data { BMenuBar *menuBar; @@ -509,13 +510,16 @@ BMenuBar::RestoreFocus() BWindow *window = Window(); if (window != NULL && window->Lock()) { BHandler *handler = NULL; - if (BPrivate::gDefaultTokens.GetToken(fPrevFocusToken, B_HANDLER_TOKEN, - (void **)&handler) == B_OK) { + if (fPrevFocusToken != -1 + && gDefaultTokens.GetToken(fPrevFocusToken, B_HANDLER_TOKEN, (void **)&handler) == B_OK) { BView *view = dynamic_cast(handler); if (view != NULL && view->Window() == window) view->MakeFocus(); - } - fPrevFocusToken = -1; + fPrevFocusToken = -1; + + } else if (IsFocus()) + MakeFocus(false); + window->Unlock(); } }