git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@16015
c3d73ce0-8a6f-49c7-b76d-
6d57e0e08775
// static function for translating menu labels
// ----------------------------------------------------------------------------
// static function for translating menu labels
// ----------------------------------------------------------------------------
-static wxString TextToLabel(const wxString& rTitle)
+static wxString TextToLabel(
+ const wxString& rsTitle
+)
- wxString Title;
- const wxChar *pc;
- for (pc = rTitle.c_str(); *pc != wxT('\0'); pc++ )
+ wxString sTitle;
+ const wxChar* zPc;
+
+ for (zPc = rsTitle.c_str(); *zPc != wxT('\0'); zPc++ )
- if (*(pc+1) == wxT('&'))
+ if (*(zPc + 1) == wxT('&'))
- pc++;
- Title << wxT('&');
+ zPc++;
+ sTitle << wxT('&');
+ if ( *zPc == wxT('~') )
- // tildes must be doubled to prevent them from being
+ //
+ // Tildes must be doubled to prevent them from being
// interpreted as accelerator character prefix by PM ???
// interpreted as accelerator character prefix by PM ???
+ return sTitle;
+} // end of TextToLabel
// ============================================================================
// implementation
// ============================================================================
// implementation
{
Append( idMenuTitle
,m_title
{
Append( idMenuTitle
,m_title
+ ,wxEmptyString
+ ,wxITEM_NORMAL
UpdateAccel(pItem);
#endif // wxUSE_ACCEL
UpdateAccel(pItem);
#endif // wxUSE_ACCEL
- //
- // rItem is the member MENUITEM for the menu items and the submenu's
- // MENUITEM for submenus as required by ::MM_INSERTITEM message API
- //
-
- if(pSubmenu != NULL)
- {
- wxASSERT_MSG(pSubmenu->GetHMenu(), wxT("invalid submenu"));
- pSubmenu->SetParent(this);
- rItem.afStyle |= MIS_SUBMENU | MIS_TEXT;
- }
-
//
// If "Break" has just been called, insert a menu break before this item
// (and don't forget to reset the flag)
//
// If "Break" has just been called, insert a menu break before this item
// (and don't forget to reset the flag)
pSubmenu->SetParent(this);
rItem.iPosition = 0; // submenus have a 0 position
pSubmenu->SetParent(this);
rItem.iPosition = 0; // submenus have a 0 position
- rItem.id = (USHORT)pSubmenu->GetHMenu();
- rItem.afStyle |= MIS_SUBMENU | MIS_TEXT;
+ rItem.id = (USHORT)pSubmenu->GetHMenu();
+ rItem.afStyle |= MIS_SUBMENU | MIS_TEXT;
// item draws itself, passing pointer to data doesn't work in OS/2
// Will eventually need to set the image handle somewhere into vItem.hItem
//
// item draws itself, passing pointer to data doesn't work in OS/2
// Will eventually need to set the image handle somewhere into vItem.hItem
//
- rItem.afStyle |= MIS_OWNERDRAW;
- pData = (BYTE*)NULL;
- rItem.hItem = (HBITMAP)pItem->GetBitmap().GetHBITMAP();
+ rItem.afStyle |= MIS_OWNERDRAW;
+ pData = (BYTE*)NULL;
+ rItem.hItem = (HBITMAP)pItem->GetBitmap().GetHBITMAP();
pItem->m_vMenuData.afStyle = rItem.afStyle;
pItem->m_vMenuData.afStyle = rItem.afStyle;
- pItem->m_vMenuData.hItem = rItem.hItem;
+ pItem->m_vMenuData.hItem = rItem.hItem;
- wxString Title = TextToLabel(rTitle);
+ wxString sTitle = TextToLabel(rTitle);
wxMenu* pMenuOld = wxMenuBarBase::Replace( nPos
,pMenu
wxMenu* pMenuOld = wxMenuBarBase::Replace( nPos
,pMenu
return NULL;
}
if (!pMenuOld)
return NULL;
}
if (!pMenuOld)
- return FALSE;
- m_titles[nPos] = Title;
+ return NULL;
+ m_titles[nPos] = sTitle;
if (IsAttached())
{
::WinSendMsg((HWND)m_hMenu, MM_REMOVEITEM, MPFROM2SHORT(nId, TRUE), (MPARAM)0);
if (IsAttached())
{
::WinSendMsg((HWND)m_hMenu, MM_REMOVEITEM, MPFROM2SHORT(nId, TRUE), (MPARAM)0);
- ::WinSendMsg((HWND)m_hMenu, MM_INSERTITEM, (MPARAM)&pMenu->m_vMenuData, (MPARAM)Title.c_str());
+ ::WinSendMsg((HWND)m_hMenu, MM_INSERTITEM, (MPARAM)&pMenu->m_vMenuData, (MPARAM)sTitle.c_str());
#if wxUSE_ACCEL
if (pMenuOld->HasAccels() || pMenu->HasAccels())
#if wxUSE_ACCEL
if (pMenuOld->HasAccels() || pMenu->HasAccels())
, const wxString& rTitle
)
{
, const wxString& rTitle
)
{
- wxString Title = TextToLabel(rTitle);
+ wxString sTitle = TextToLabel(rTitle);
+
if (!wxMenuBarBase::Insert( nPos
,pMenu
if (!wxMenuBarBase::Insert( nPos
,pMenu
+ m_titles.Insert( sTitle
,nPos
);
if (IsAttached())
{
,nPos
);
if (IsAttached())
{
- ::WinSendMsg((HWND)m_hMenu, MM_INSERTITEM, (MPARAM)&pMenu->m_vMenuData, (MPARAM)Title.c_str());
+ pMenu->m_vMenuData.iPosition = nPos;
+ ::WinSendMsg( (HWND)m_hMenu
+ ,MM_INSERTITEM
+ ,(MPARAM)&pMenu->m_vMenuData
+ ,(MPARAM)sTitle.c_str()
+ );
#if wxUSE_ACCEL
if (pMenu->HasAccels())
{
#if wxUSE_ACCEL
if (pMenu->HasAccels())
{
bool wxMenuBar::Append(
wxMenu* pMenu
bool wxMenuBar::Append(
wxMenu* pMenu
-, const wxString& rTitle
+, const wxString& rsTitle
)
{
WXHMENU hSubmenu = pMenu ? pMenu->GetHMenu() : 0;
wxCHECK_MSG(hSubmenu, FALSE, wxT("can't append invalid menu to menubar"));
)
{
WXHMENU hSubmenu = pMenu ? pMenu->GetHMenu() : 0;
wxCHECK_MSG(hSubmenu, FALSE, wxT("can't append invalid menu to menubar"));
- wxString Title = TextToLabel(rTitle);
- if (!wxMenuBarBase::Append(pMenu, Title))
+ wxString sTitle = TextToLabel(rsTitle);
+
+ if (!wxMenuBarBase::Append(pMenu, sTitle))
if ( IsAttached() )
{
pMenu->m_vMenuData.iPosition = MIT_END;
if ( IsAttached() )
{
pMenu->m_vMenuData.iPosition = MIT_END;
- ::WinSendMsg((HWND)m_hMenu, MM_INSERTITEM, (MPARAM)&pMenu->m_vMenuData, (MPARAM)Title.c_str());
+ ::WinSendMsg((HWND)m_hMenu, MM_INSERTITEM, (MPARAM)&pMenu->m_vMenuData, (MPARAM)sTitle.c_str());
#if wxUSE_ACCEL
if (pMenu->HasAccels())
{
#if wxUSE_ACCEL
if (pMenu->HasAccels())
{
- nId = SHORT1FROMMR(::WinSendMsg((HWND)GetHmenu(), MM_ITEMIDFROMPOSITION, MPFROMSHORT(nPos), (MPARAM)0));
+ nId = SHORT1FROMMR(::WinSendMsg( (HWND)GetHmenu()
+ ,MM_ITEMIDFROMPOSITION
+ ,MPFROMSHORT(nPos)
+ ,(MPARAM)0)
+ );
if (nId == MIT_ERROR)
{
wxLogLastError("LogLastError");
if (nId == MIT_ERROR)
{
wxLogLastError("LogLastError");
- ::WinSendMsg((HWND)GetHmenu(), MM_REMOVEITEM, MPFROM2SHORT(nId, TRUE), (MPARAM)0);
+ ::WinSendMsg( (HWND)GetHmenu()
+ ,MM_REMOVEITEM
+ ,MPFROM2SHORT(nId, TRUE)
+ ,(MPARAM)0
+ );
#if wxUSE_ACCEL
if (pMenu->HasAccels())
#if wxUSE_ACCEL
if (pMenu->HasAccels())
// static function for translating menu labels
// ----------------------------------------------------------------------------
// static function for translating menu labels
// ----------------------------------------------------------------------------
-static wxString TextToLabel(const wxString& rTitle)
+static wxString TextToLabel(
+ const wxString& rsTitle
+)
- wxString Title;
- const wxChar *pc;
- for (pc = rTitle.c_str(); *pc != wxT('\0'); pc++ )
+ wxString sTitle;
+ const wxChar* zPc;
+
+ if (rsTitle.IsEmpty())
+ return(sTitle);
+
+ for (zPc = rsTitle.c_str(); *zPc != wxT('\0'); zPc++)
- if (*(pc+1) == wxT('&'))
+ if (*(zPc + 1) == wxT('&'))
- pc++;
- Title << wxT('&');
+ zPc++;
+ sTitle << wxT('&');
- // tildes must be doubled to prevent them from being
+ //
+ // Tildes must be doubled to prevent them from being
// interpreted as accelerator character prefix by PM ???
// interpreted as accelerator character prefix by PM ???
+ return(sTitle);
+} // end of TextToLabel
// ============================================================================
// implementation
// ============================================================================
// implementation
SetTextColour(SYS_COLOR(MENUTEXT));
SetBackgroundColour(SYS_COLOR(MENU));
SetTextColour(SYS_COLOR(MENUTEXT));
SetBackgroundColour(SYS_COLOR(MENU));
//
// We don't want normal items be owner-drawn
//
ResetOwnerDrawn();
//
// We don't want normal items be owner-drawn
//
ResetOwnerDrawn();
//
// Tell the owner drawing code to to show the accel string as well
//
// Tell the owner drawing code to to show the accel string as well
} // end of wxMenuItem::IsChecked
wxString wxMenuItemBase::GetLabelFromText(
} // end of wxMenuItem::IsChecked
wxString wxMenuItemBase::GetLabelFromText(
- wxString label;
- for ( const wxChar *pc = rText.c_str(); *pc; pc++ )
+ wxString sLabel;
+
+ for (const char* zPc = rsText.c_str(); *zPc; zPc++)
- if ( *pc == wxT('~') || *pc == wxT('&') )
+ if (*zPc == wxT('~') || *zPc == wxT('&'))
- // '~' is the escape character for GTK+ and '&' is the one for
+ //
+ // '~' is the escape character for OS/2PM and '&' is the one for
// wxWindows - skip both of them
// wxWindows - skip both of them
+ return sLabel;
+} // end of wxMenuItemBase::GetLabelFromText