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:
@@ -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();
|
||||||
|
@@ -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.
|
||||||
|
@@ -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
|
||||||
}
|
}
|
||||||
|
@@ -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 )
|
||||||
{
|
{
|
||||||
|
Reference in New Issue
Block a user