fix several problems in handling of the menu items with negative ids

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@50033 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Vadim Zeitlin
2007-11-17 20:38:07 +00:00
parent a368dde565
commit 660e7fda2c
4 changed files with 26 additions and 15 deletions

View File

@@ -53,8 +53,11 @@ public:
// the id for a popup menu is really its menu handle (as required by // the id for a popup menu is really its menu handle (as required by
// ::AppendMenu() API), so this function will return either the id or the // ::AppendMenu() API), so this function will return either the id or the
// menu handle depending on what we're // menu handle depending on what we are
int GetRealId() const; //
// notice that it also returns the id as an unsigned int, as required by
// Win32 API
unsigned GetMSWId() const;
// mark item as belonging to the given radio group // mark item as belonging to the given radio group
void SetAsRadioGroupStart(); void SetAsRadioGroupStart();

View File

@@ -946,8 +946,11 @@ bool wxFrame::HandleSize(int WXUNUSED(x), int WXUNUSED(y), WXUINT id)
return false; return false;
} }
bool wxFrame::HandleCommand(WXWORD id, WXWORD cmd, WXHWND control) bool wxFrame::HandleCommand(WXWORD id_, WXWORD cmd, WXHWND control)
{ {
// sign extend to int from short before comparing with the other int ids
int id = (signed short)id_;
if ( control ) if ( control )
{ {
// In case it's e.g. a toolbar. // In case it's e.g. a toolbar.

View File

@@ -97,7 +97,7 @@ typedef struct tagMENUINFO
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
// the (popup) menu title has this special id // the (popup) menu title has this special id
static const int idMenuTitle = -3; static const UINT idMenuTitle = (UINT)-3;
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
// private functions // private functions
@@ -399,7 +399,7 @@ bool wxMenu::DoInsertOrAppend(wxMenuItem *pItem, size_t pos)
flags |= MF_POPUP; flags |= MF_POPUP;
} }
else { else {
id = pItem->GetId(); id = pItem->GetMSWId();
} }
@@ -564,7 +564,7 @@ bool wxMenu::DoInsertOrAppend(wxMenuItem *pItem, size_t pos)
// if we just appended the title, highlight it // if we just appended the title, highlight it
if ( (int)id == idMenuTitle ) if ( id == idMenuTitle )
{ {
// visually select the menu title // visually select the menu title
SetDefaultMenuItem(GetHmenu(), id); SetDefaultMenuItem(GetHmenu(), id);
@@ -731,7 +731,7 @@ void wxMenu::SetTitle(const wxString& label)
if ( !label.empty() ) if ( !label.empty() )
{ {
if ( !::InsertMenu(hMenu, 0u, MF_BYPOSITION | MF_STRING, if ( !::InsertMenu(hMenu, 0u, MF_BYPOSITION | MF_STRING,
(unsigned)idMenuTitle, m_title.wx_str()) || idMenuTitle, m_title.wx_str()) ||
!::InsertMenu(hMenu, 1u, MF_BYPOSITION, (unsigned)-1, NULL) ) !::InsertMenu(hMenu, 1u, MF_BYPOSITION, (unsigned)-1, NULL) )
{ {
wxLogLastError(wxT("InsertMenu")); wxLogLastError(wxT("InsertMenu"));
@@ -767,7 +767,7 @@ void wxMenu::SetTitle(const wxString& label)
#else #else
if ( !ModifyMenu(hMenu, 0u, if ( !ModifyMenu(hMenu, 0u,
MF_BYPOSITION | MF_STRING, MF_BYPOSITION | MF_STRING,
(unsigned)idMenuTitle, m_title.wx_str()) ) idMenuTitle, m_title.wx_str()) )
{ {
wxLogLastError(wxT("ModifyMenu")); wxLogLastError(wxT("ModifyMenu"));
} }
@@ -779,7 +779,7 @@ void wxMenu::SetTitle(const wxString& label)
// put the title string in bold face // put the title string in bold face
if ( !m_title.empty() ) if ( !m_title.empty() )
{ {
SetDefaultMenuItem(GetHmenu(), (UINT)idMenuTitle); SetDefaultMenuItem(GetHmenu(), idMenuTitle);
} }
#endif // Win32 #endif // Win32
} }

View File

@@ -186,9 +186,14 @@ wxMenuItem::~wxMenuItem()
// ---- // ----
// return the id for calling Win32 API functions // return the id for calling Win32 API functions
int wxMenuItem::GetRealId() const unsigned wxMenuItem::GetMSWId() const
{ {
return m_subMenu ? (int)m_subMenu->GetHMenu() : GetId(); // we must use ids in unsigned short range with Windows functions, if we
// pass ids > USHRT_MAX to them they get very confused (e.g. start
// generating WM_COMMAND messages with negative high word of wParam), so
// use the cast to ensure the id is in range
return m_subMenu ? wx_reinterpret_cast(unsigned, m_subMenu->GetHMenu())
: wx_static_cast(unsigned short, GetId());
} }
// get item state // get item state
@@ -201,7 +206,7 @@ bool wxMenuItem::IsChecked() const
if ( GetId() == wxID_SEPARATOR ) if ( GetId() == wxID_SEPARATOR )
return false ; return false ;
int flag = ::GetMenuState(GetHMenuOf(m_parentMenu), GetId(), MF_BYCOMMAND); int flag = ::GetMenuState(GetHMenuOf(m_parentMenu), GetMSWId(), MF_BYCOMMAND);
return (flag & MF_CHECKED) != 0; return (flag & MF_CHECKED) != 0;
} }
@@ -245,7 +250,7 @@ void wxMenuItem::Enable(bool enable)
return; return;
long rc = EnableMenuItem(GetHMenuOf(m_parentMenu), long rc = EnableMenuItem(GetHMenuOf(m_parentMenu),
GetRealId(), GetMSWId(),
MF_BYCOMMAND | MF_BYCOMMAND |
(enable ? MF_ENABLED : MF_GRAYED)); (enable ? MF_ENABLED : MF_GRAYED));
@@ -327,7 +332,7 @@ void wxMenuItem::Check(bool check)
else // check item else // check item
{ {
if ( ::CheckMenuItem(hmenu, if ( ::CheckMenuItem(hmenu,
GetRealId(), GetMSWId(),
MF_BYCOMMAND | flags) == (DWORD)-1 ) MF_BYCOMMAND | flags) == (DWORD)-1 )
{ {
wxFAIL_MSG( _T("CheckMenuItem() failed, item not in the menu?") ); wxFAIL_MSG( _T("CheckMenuItem() failed, item not in the menu?") );
@@ -364,7 +369,7 @@ void wxMenuItem::SetItemLabel(const wxString& txt)
m_parentMenu->UpdateAccel(this); m_parentMenu->UpdateAccel(this);
#endif // wxUSE_ACCEL #endif // wxUSE_ACCEL
UINT id = GetRealId(); UINT id = GetMSWId();
UINT flagsOld = ::GetMenuState(hMenu, id, MF_BYCOMMAND); UINT flagsOld = ::GetMenuState(hMenu, id, MF_BYCOMMAND);
if ( flagsOld == 0xFFFFFFFF ) if ( flagsOld == 0xFFFFFFFF )
{ {