git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@6826
c3d73ce0-8a6f-49c7-b76d-
6d57e0e08775
IMPLEMENT_DYNAMIC_CLASS(wxMenu, wxEvtHandler)
IMPLEMENT_DYNAMIC_CLASS(wxMenuBar, wxEvtHandler)
IMPLEMENT_DYNAMIC_CLASS(wxMenu, wxEvtHandler)
IMPLEMENT_DYNAMIC_CLASS(wxMenuBar, wxEvtHandler)
+// ----------------------------------------------------------------------------
+// static function for translating menu labels
+// ----------------------------------------------------------------------------
+
+static wxString TextToLabel(const wxString& rTitle)
+{
+ wxString Title;
+ const wxChar *pc;
+ for (pc = rTitle; *pc != wxT('\0'); pc++ )
+ {
+ if (*pc == wxT('&') )
+ {
+ if (*(pc+1) == wxT('&'))
+ {
+ pc++;
+ Title << wxT('&');
+ }
+ else
+ Title << wxT('~');
+ }
+// else if (*pc == wxT('/'))
+// {
+// Title << wxT('\\');
+// }
+ else
+ {
+ if ( *pc == wxT('~') )
+ {
+ // tildes must be doubled to prevent them from being
+ // interpreted as accelerator character prefix by PM ???
+ Title << *pc;
+ }
+ Title << *pc;
+ }
+ }
+ return Title;
+}
+
// ============================================================================
// implementation
// ============================================================================
// ============================================================================
// implementation
// ============================================================================
+ wxString Title = TextToLabel(rTitle);
wxMenu* pMenuOld = wxMenuBarBase::Replace( nPos
,pMenu
wxMenu* pMenuOld = wxMenuBarBase::Replace( nPos
,pMenu
}
if (!pMenuOld)
return FALSE;
}
if (!pMenuOld)
return FALSE;
- m_titles[nPos] = rTitle;
+ m_titles[nPos] = Title;
if (IsAttached())
{
::WinSendMsg((HWND)m_hMenu, MM_DELETEITEM, MPFROM2SHORT(nId, TRUE), (MPARAM)0);
if (IsAttached())
{
::WinSendMsg((HWND)m_hMenu, MM_DELETEITEM, MPFROM2SHORT(nId, TRUE), (MPARAM)0);
- ::WinSendMsg((HWND)m_hMenu, MM_INSERTITEM, (MPARAM)&pMenu->m_vMenuData, (MPARAM)rTitle.c_str());
+ ::WinSendMsg((HWND)m_hMenu, MM_INSERTITEM, (MPARAM)&pMenu->m_vMenuData, (MPARAM)Title.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);
if (!wxMenuBarBase::Insert( nPos
,pMenu
if (!wxMenuBarBase::Insert( nPos
,pMenu
- m_titles.Insert( rTitle
- ::WinSendMsg((HWND)m_hMenu, MM_INSERTITEM, (MPARAM)&pMenu->m_vMenuData, (MPARAM)rTitle.c_str());
+ ::WinSendMsg((HWND)m_hMenu, MM_INSERTITEM, (MPARAM)&pMenu->m_vMenuData, (MPARAM)Title.c_str());
#if wxUSE_ACCEL
if (pMenu->HasAccels())
{
#if wxUSE_ACCEL
if (pMenu->HasAccels())
{
wxCHECK_MSG(hSubmenu, FALSE, wxT("can't append invalid menu to menubar"));
wxCHECK_MSG(hSubmenu, FALSE, wxT("can't append invalid menu to menubar"));
- if (!wxMenuBarBase::Append(pMenu, rTitle))
+ wxString Title = TextToLabel(rTitle);
+ if (!wxMenuBarBase::Append(pMenu, Title))
return FALSE;
pMenu->Attach(this);
return FALSE;
pMenu->Attach(this);
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)rTitle.c_str());
+ ::WinSendMsg((HWND)m_hMenu, MM_INSERTITEM, (MPARAM)&pMenu->m_vMenuData, (MPARAM)Title.c_str());
#if wxUSE_ACCEL
if (pMenu->HasAccels())
{
#if wxUSE_ACCEL
if (pMenu->HasAccels())
{
#define OWNER_DRAWN_ONLY( code )
#endif // wxUSE_OWNER_DRAWN/!wxUSE_OWNER_DRAWN
#define OWNER_DRAWN_ONLY( code )
#endif // wxUSE_OWNER_DRAWN/!wxUSE_OWNER_DRAWN
+// ----------------------------------------------------------------------------
+// static function for translating menu labels
+// ----------------------------------------------------------------------------
+
+static wxString TextToLabel(const wxString& rTitle)
+{
+ wxString Title;
+ const wxChar *pc;
+ for (pc = rTitle; *pc != wxT('\0'); pc++ )
+ {
+ if (*pc == wxT('&') )
+ {
+ if (*(pc+1) == wxT('&'))
+ {
+ pc++;
+ Title << wxT('&');
+ }
+ else
+ Title << wxT('~');
+ }
+// else if (*pc == wxT('/'))
+// {
+// Title << wxT('\\');
+// }
+ else
+ {
+ if ( *pc == wxT('~') )
+ {
+ // tildes must be doubled to prevent them from being
+ // interpreted as accelerator character prefix by PM ???
+ Title << *pc;
+ }
+ Title << *pc;
+ }
+ }
+ return Title;
+}
+
// ============================================================================
// implementation
// ============================================================================
// ============================================================================
// implementation
// ============================================================================
, wxMenu* pSubMenu
)
#if wxUSE_OWNER_DRAWN
, wxMenu* pSubMenu
)
#if wxUSE_OWNER_DRAWN
+: wxOwnerDrawn( TextToLabel(rText)
,bCheckable
)
#endif // owner drawn
,bCheckable
)
#endif // owner drawn
m_isEnabled = TRUE;
m_isChecked = FALSE;
m_id = nId;
m_isEnabled = TRUE;
m_isChecked = FALSE;
m_id = nId;
+ m_text = TextToLabel(rText);
m_isCheckable = bCheckable;
m_help = rStrHelp;
} // end of wxMenuItem::wxMenuItem
m_isCheckable = bCheckable;
m_help = rStrHelp;
} // end of wxMenuItem::wxMenuItem
const wxString& rText
)
{
const wxString& rText
)
{
- return wxStripMenuCodes(rText);
+ wxString label;
+ for ( const wxChar *pc = rText.c_str(); *pc; pc++ )
+ {
+ if ( *pc == wxT('~') || *pc == wxT('&') )
+ {
+ // '~' is the escape character for GTK+ and '&' is the one for
+ // wxWindows - skip both of them
+ continue;
+ }
+
+ label += *pc;
+ }
+ return label;
//
// Don't do anything if label didn't change
//
//
// Don't do anything if label didn't change
//
+
+ wxString Text = TextToLabel(rText);
+ if (m_text == Text)
- wxMenuItemBase::SetText(rText);
- OWNER_DRAWN_ONLY(wxOwnerDrawn::SetName(rText));
+ wxMenuItemBase::SetText(Text);
+ OWNER_DRAWN_ONLY(wxOwnerDrawn::SetName(Text));
HWND hMenu = GetHMenuOf(m_parentMenu);
HWND hMenu = GetHMenuOf(m_parentMenu);
#endif //owner drawn
{
uFlagsOld |= MIS_TEXT;
#endif //owner drawn
{
uFlagsOld |= MIS_TEXT;
- pData = (BYTE*)rText.c_str();
+ pData = (BYTE*)Text.c_str();