X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/0472ece753aa3c018dd2cc9816d3cd755f28efe8..f7f78039d2e18114efdec0abe46dc4ed2d4529a8:/src/msw/menu.cpp diff --git a/src/msw/menu.cpp b/src/msw/menu.cpp index ec96dc7bc8..b3005be6cc 100644 --- a/src/msw/menu.cpp +++ b/src/msw/menu.cpp @@ -5,8 +5,8 @@ // Modified by: Vadim Zeitlin // Created: 04/01/98 // RCS-ID: $Id$ -// Copyright: (c) Julian Smart and Markus Holzem -// Licence: wxWindows license +// Copyright: (c) Julian Smart +// Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// // =========================================================================== @@ -299,28 +299,6 @@ bool wxMenu::DoInsertOrAppend(wxMenuItem *pItem, size_t pos) void wxMenu::EndRadioGroup() { - if ( m_startRadioGroup == -1 ) - { - // nothing to do - return; - } - - wxMenuItemList::Node *nodeStart = GetMenuItems().Item(m_startRadioGroup); - wxCHECK_RET( nodeStart, _T("where is the radio group start item?") ); - - int endRadioGroup = GetMenuItemCount(); - - wxMenuItemList::Node *node = nodeStart; - for ( int n = m_startRadioGroup; n < endRadioGroup && node; n++ ) - { - wxMenuItem *item = (wxMenuItem *)node->GetData(); - item->SetRadioGroup(m_startRadioGroup, endRadioGroup - 1); - - node = node->GetNext(); - } - - nodeStart->GetData()->Check(TRUE); - // we're not inside a radio group any longer m_startRadioGroup = -1; } @@ -329,12 +307,38 @@ bool wxMenu::DoAppend(wxMenuItem *item) { wxCHECK_MSG( item, FALSE, _T("NULL item in wxMenu::DoAppend") ); - if ( item->GetKind() == wxItem_Radio ) + bool check = FALSE; + + if ( item->GetKind() == wxITEM_RADIO ) { + int count = GetMenuItemCount(); + if ( m_startRadioGroup == -1 ) { // start a new radio group - m_startRadioGroup = GetMenuItemCount(); + m_startRadioGroup = count; + + // for now it has just one element + item->SetAsRadioGroupStart(); + item->SetRadioGroupEnd(m_startRadioGroup); + + // ensure that we have a checked item in the radio group + check = TRUE; + } + else // extend the current radio group + { + // we need to update its end item + item->SetRadioGroupStart(m_startRadioGroup); + wxMenuItemList::Node *node = GetMenuItems().Item(m_startRadioGroup); + + if ( node ) + { + node->GetData()->SetRadioGroupEnd(count); + } + else + { + wxFAIL_MSG( _T("where is the radio group start item?") ); + } } } else // not a radio item @@ -342,7 +346,18 @@ bool wxMenu::DoAppend(wxMenuItem *item) EndRadioGroup(); } - return wxMenuBase::DoAppend(item) && DoInsertOrAppend(item); + if ( !wxMenuBase::DoAppend(item) || !DoInsertOrAppend(item) ) + { + return FALSE; + } + + if ( check ) + { + // check the item initially + item->Check(TRUE); + } + + return TRUE; } bool wxMenu::DoInsert(size_t pos, wxMenuItem *item) @@ -542,6 +557,13 @@ wxMenuBar::wxMenuBar(int count, wxMenu *menus[], const wxString titles[]) wxMenuBar::~wxMenuBar() { + // we should free Windows resources only if Windows doesn't do it for us + // which happens if we're attached to a frame + if (m_hMenu && !IsAttached()) + { + ::DestroyMenu((HMENU)m_hMenu); + m_hMenu = (WXHMENU)NULL; + } } // --------------------------------------------------------------------------- @@ -658,7 +680,8 @@ wxMenu *wxMenuBar::Replace(size_t pos, wxMenu *menu, const wxString& title) { wxMenu *menuOld = wxMenuBarBase::Replace(pos, menu, title); if ( !menuOld ) - return FALSE; + return NULL; + m_titles[pos] = title; if ( IsAttached() ) @@ -822,8 +845,6 @@ void wxMenuBar::Attach(wxFrame *frame) void wxMenuBar::Detach() { - m_hMenu = (WXHMENU)NULL; - wxMenuBarBase::Detach(); }