projects
/
wxWidgets.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
No *.h in src/common/ anymore.
[wxWidgets.git]
/
src
/
os2
/
menu.cpp
diff --git
a/src/os2/menu.cpp
b/src/os2/menu.cpp
index 09b81199006ab1c1d721c3fb23ce04322541d983..ccb4be42512ae2669bbadb1fb340756d15e2052f 100644
(file)
--- a/
src/os2/menu.cpp
+++ b/
src/os2/menu.cpp
@@
-47,7
+47,7
@@
extern wxMenu* wxCurrentPopupMenu;
//
// The (popup) menu title has this special id
//
//
// The (popup) menu title has this special id
//
-static const int idMenuTitle = -
2
;
+static const int idMenuTitle = -
3
;
//
// The unique ID for Menus
//
// The unique ID for Menus
@@
-179,12
+179,12
@@
void wxMenu::UpdateAccel(
if (pItem->IsSubMenu())
{
wxMenu* pSubmenu = pItem->GetSubMenu();
if (pItem->IsSubMenu())
{
wxMenu* pSubmenu = pItem->GetSubMenu();
- wxMenuItemList::
Node* pN
ode = pSubmenu->GetMenuItems().GetFirst();
+ wxMenuItemList::
compatibility_iterator n
ode = pSubmenu->GetMenuItems().GetFirst();
- while (
pN
ode)
+ while (
n
ode)
{
{
- UpdateAccel(
pN
ode->GetData());
-
pNode = pN
ode->GetNext();
+ UpdateAccel(
n
ode->GetData());
+
node = n
ode->GetNext();
}
}
else if (!pItem->IsSeparator())
}
}
else if (!pItem->IsSeparator())
@@
-202,7
+202,7
@@
void wxMenu::UpdateAccel(
//
size_t n = FindAccel(pItem->GetId());
//
size_t n = FindAccel(pItem->GetId());
- if (n == wxNOT_FOUND)
+ if (n ==
(size_t)
wxNOT_FOUND)
{
//
// No old, add new if any
{
//
// No old, add new if any
@@
-226,7
+226,7
@@
void wxMenu::UpdateAccel(
if (IsAttached())
{
if (IsAttached())
{
-
m_menuBar
->RebuildAccelTable();
+
GetMenuBar()
->RebuildAccelTable();
}
}
} // wxMenu::UpdateAccel
}
}
} // wxMenu::UpdateAccel
@@
-247,7
+247,6
@@
bool wxMenu::DoInsertOrAppend(
ERRORID vError;
wxString sError;
ERRORID vError;
wxString sError;
- char zMsg[128];
#if wxUSE_ACCEL
UpdateAccel(pItem);
#if wxUSE_ACCEL
UpdateAccel(pItem);
@@
-281,7
+280,7
@@
bool wxMenu::DoInsertOrAppend(
rItem.id = pItem->GetId();
}
rItem.id = pItem->GetId();
}
- BYTE* pData;
+ BYTE* pData
=NULL
;
#if wxUSE_OWNER_DRAWN
if (pItem->IsOwnerDrawn())
#if wxUSE_OWNER_DRAWN
if (pItem->IsOwnerDrawn())
@@
-305,10
+304,18
@@
bool wxMenu::DoInsertOrAppend(
}
else
{
}
else
{
- //
- // Menu is just a normal string (passed in data parameter)
- //
- rItem.afStyle |= MIS_TEXT;
+ if (pItem->GetId() == idMenuTitle)
+ {
+ // Item is an unselectable title to be passed via pData
+ rItem.afStyle = MIS_STATIC;
+ }
+ else
+ {
+ //
+ // Menu is just a normal string (passed in data parameter)
+ //
+ rItem.afStyle |= MIS_TEXT;
+ }
pData = (char*)pItem->GetText().c_str();
}
pData = (char*)pItem->GetText().c_str();
}
@@
-331,7
+338,6
@@
bool wxMenu::DoInsertOrAppend(
#if wxUSE_OWNER_DRAWN
if (pItem->IsOwnerDrawn())
{
#if wxUSE_OWNER_DRAWN
if (pItem->IsOwnerDrawn())
{
- BOOL rc;
MENUITEM vMenuItem;
::WinSendMsg( GetHmenu()
MENUITEM vMenuItem;
::WinSendMsg( GetHmenu()
@@
-343,7
+349,7
@@
bool wxMenu::DoInsertOrAppend(
);
}
#endif
);
}
#endif
- if (rc ==
MIT_MEMERROR || rc ==
MIT_ERROR)
+ if (rc ==
(APIRET)MIT_MEMERROR || rc == (APIRET)
MIT_ERROR)
{
vError = ::WinGetLastError(vHabmain);
sError = wxPMErrorToStr(vError);
{
vError = ::WinGetLastError(vHabmain);
sError = wxPMErrorToStr(vError);
@@
-356,9
+362,9
@@
bool wxMenu::DoInsertOrAppend(
//
// If we're already attached to the menubar, we must update it
//
//
// If we're already attached to the menubar, we must update it
//
- if (IsAttached() &&
m_menuBar
->IsAttached())
+ if (IsAttached() &&
GetMenuBar()
->IsAttached())
{
{
-
m_menuBar
->Refresh();
+
GetMenuBar()
->Refresh();
}
return TRUE;
}
}
return TRUE;
}
@@
-410,11
+416,11
@@
wxMenuItem* wxMenu::DoAppend(
//
pItem->SetRadioGroupStart(m_nStartRadioGroup);
//
pItem->SetRadioGroupStart(m_nStartRadioGroup);
- wxMenuItemList::
Node* pN
ode = GetMenuItems().Item(m_nStartRadioGroup);
+ wxMenuItemList::
compatibility_iterator n
ode = GetMenuItems().Item(m_nStartRadioGroup);
- if (
pN
ode)
+ if (
n
ode)
{
{
-
pN
ode->GetData()->SetRadioGroupEnd(nCount);
+
n
ode->GetData()->SetRadioGroupEnd(nCount);
}
else
{
}
else
{
@@
-464,19
+470,19
@@
wxMenuItem* wxMenu::DoRemove(
// We need to find the items position in the child list
//
size_t nPos;
// We need to find the items position in the child list
//
size_t nPos;
- wxMenuItemList::
Node* pN
ode = GetMenuItems().GetFirst();
+ wxMenuItemList::
compatibility_iterator n
ode = GetMenuItems().GetFirst();
- for (nPos = 0;
pN
ode; nPos++)
+ for (nPos = 0;
n
ode; nPos++)
{
{
- if (
pN
ode->GetData() == pItem)
+ if (
n
ode->GetData() == pItem)
break;
break;
-
pNode = pN
ode->GetNext();
+
node = n
ode->GetNext();
}
//
// DoRemove() (unlike Remove) can only be called for existing item!
//
}
//
// DoRemove() (unlike Remove) can only be called for existing item!
//
- wxCHECK_MSG(
pN
ode, NULL, wxT("bug in wxMenu::Remove logic"));
+ wxCHECK_MSG(
n
ode, NULL, wxT("bug in wxMenu::Remove logic"));
#if wxUSE_ACCEL
//
#if wxUSE_ACCEL
//
@@
-499,12
+505,12
@@
wxMenuItem* wxMenu::DoRemove(
,MPFROM2SHORT(pItem->GetId(), TRUE)
,(MPARAM)0
);
,MPFROM2SHORT(pItem->GetId(), TRUE)
,(MPARAM)0
);
- if (IsAttached() &&
m_menuBar
->IsAttached())
+ if (IsAttached() &&
GetMenuBar()
->IsAttached())
{
//
// Otherwise, the chane won't be visible
//
{
//
// Otherwise, the chane won't be visible
//
-
m_menuBar
->Refresh();
+
GetMenuBar()
->Refresh();
}
//
}
//
@@
-601,7
+607,7
@@
bool wxMenu::OS2Command(
SendEvent( vId
,(int)::WinSendMsg( GetHmenu()
,MM_QUERYITEMATTR
SendEvent( vId
,(int)::WinSendMsg( GetHmenu()
,MM_QUERYITEMATTR
- ,
(MPARAM)vId
+ ,
MPFROMSHORT(vId)
,(MPARAM)MIA_CHECKED
)
);
,(MPARAM)MIA_CHECKED
)
);
@@
-617,8
+623,8
@@
wxWindow* wxMenu::GetWindow() const
{
if (m_invokingWindow != NULL)
return m_invokingWindow;
{
if (m_invokingWindow != NULL)
return m_invokingWindow;
- else if (
m_menuBar
!= NULL)
- return
m_menuBar
->GetFrame();
+ else if (
GetMenuBar()
!= NULL)
+ return
GetMenuBar()
->GetFrame();
return NULL;
} // end of wxMenu::GetWindow
return NULL;
} // end of wxMenu::GetWindow
@@
-635,7
+641,7
@@
wxMenuItem* wxMenu::FindItem(
wxMenuItem* pItem = NULL;
wxMenuItem* pItem = NULL;
- for ( wxMenuItemList::
Node *
node = m_items.GetFirst();
+ for ( wxMenuItemList::
compatibility_iterator
node = m_items.GetFirst();
node && !pItem;
node = node->GetNext() )
{
node && !pItem;
node = node->GetNext() )
{
@@
-730,7
+736,6
@@
void wxMenuBar::Refresh()
WXHMENU wxMenuBar::Create()
{
WXHMENU wxMenuBar::Create()
{
- MENUITEM vItem;
HWND hFrame;
if (m_hMenu != 0 )
HWND hFrame;
if (m_hMenu != 0 )
@@
-767,9
+772,9
@@
WXHMENU wxMenuBar::Create()
}
else
{
}
else
{
- size_t nCount = GetMenuCount();
-
- for (
size_t i = 0; i < nCount; i
++)
+ size_t nCount = GetMenuCount()
, i
;
+ wxMenuList::iterator it;
+ for (
i = 0, it = m_menus.begin(); i < nCount; i++, it
++)
{
APIRET rc;
ERRORID vError;
{
APIRET rc;
ERRORID vError;
@@
-779,8
+784,8
@@
WXHMENU wxMenuBar::Create()
//
// Set the parent and owner of the submenues to be the menubar, not the desktop
//
//
// Set the parent and owner of the submenues to be the menubar, not the desktop
//
- hSubMenu =
m_menus[i]
->m_vMenuData.hwndSubMenu;
- if (!::WinSetParent(
m_menus[i]
->m_vMenuData.hwndSubMenu, m_hMenu, FALSE))
+ hSubMenu =
(*it)
->m_vMenuData.hwndSubMenu;
+ if (!::WinSetParent(
(*it)
->m_vMenuData.hwndSubMenu, m_hMenu, FALSE))
{
vError = ::WinGetLastError(vHabmain);
sError = wxPMErrorToStr(vError);
{
vError = ::WinGetLastError(vHabmain);
sError = wxPMErrorToStr(vError);
@@
-788,7
+793,7
@@
WXHMENU wxMenuBar::Create()
return NULLHANDLE;
}
return NULLHANDLE;
}
- if (!::WinSetOwner(
m_menus[i]
->m_vMenuData.hwndSubMenu, m_hMenu))
+ if (!::WinSetOwner(
(*it)
->m_vMenuData.hwndSubMenu, m_hMenu))
{
vError = ::WinGetLastError(vHabmain);
sError = wxPMErrorToStr(vError);
{
vError = ::WinGetLastError(vHabmain);
sError = wxPMErrorToStr(vError);
@@
-796,10
+801,10
@@
WXHMENU wxMenuBar::Create()
return NULLHANDLE;
}
return NULLHANDLE;
}
-
m_menus[i]
->m_vMenuData.iPosition = i;
+
(*it)
->m_vMenuData.iPosition = i;
- rc = (APIRET)::WinSendMsg(m_hMenu, MM_INSERTITEM, (MPARAM)&
m_menus[i]
->m_vMenuData, (MPARAM)m_titles[i].c_str());
- if (rc ==
MIT_MEMERROR || rc ==
MIT_ERROR)
+ rc = (APIRET)::WinSendMsg(m_hMenu, MM_INSERTITEM, (MPARAM)&
(*it)
->m_vMenuData, (MPARAM)m_titles[i].c_str());
+ if (rc ==
(APIRET)MIT_MEMERROR || rc == (APIRET)
MIT_ERROR)
{
vError = ::WinGetLastError(vHabmain);
sError = wxPMErrorToStr(vError);
{
vError = ::WinGetLastError(vHabmain);
sError = wxPMErrorToStr(vError);
@@
-1046,7
+1051,7
@@
wxMenu* wxMenuBar::Remove(
#endif // wxUSE_ACCEL
Refresh();
}
#endif // wxUSE_ACCEL
Refresh();
}
- m_titles.Remove(nPos);
+ m_titles.Remove
At
(nPos);
return pMenu;
} // end of wxMenuBar::Remove
return pMenu;
} // end of wxMenuBar::Remove
@@
-1060,10
+1065,10
@@
void wxMenuBar::RebuildAccelTable()
size_t nAccelCount = 0;
size_t i;
size_t nCount = GetMenuCount();
size_t nAccelCount = 0;
size_t i;
size_t nCount = GetMenuCount();
-
- for (i = 0
; i < nCount; i
++)
+ wxMenuList::iterator it;
+ for (i = 0
, it = m_menus.begin(); i < nCount; i++, it
++)
{
{
- nAccelCount +=
m_menus[i]
->GetAccelCount();
+ nAccelCount +=
(*it)
->GetAccelCount();
}
if (nAccelCount)
}
if (nAccelCount)
@@
-1071,9
+1076,9
@@
void wxMenuBar::RebuildAccelTable()
wxAcceleratorEntry* pAccelEntries = new wxAcceleratorEntry[nAccelCount];
nAccelCount = 0;
wxAcceleratorEntry* pAccelEntries = new wxAcceleratorEntry[nAccelCount];
nAccelCount = 0;
- for (i = 0
; i < nCount; i
++)
+ for (i = 0
, it = m_menus.begin(); i < nCount; i++, it
++)
{
{
- nAccelCount +=
m_menus[i]
->CopyAccels(&pAccelEntries[nAccelCount]);
+ nAccelCount +=
(*it)
->CopyAccels(&pAccelEntries[nAccelCount]);
}
m_vAccelTable = wxAcceleratorTable( nAccelCount
,pAccelEntries
}
m_vAccelTable = wxAcceleratorTable( nAccelCount
,pAccelEntries
@@
-1123,14
+1128,14
@@
int wxMenuBar::FindMenuItem(
) const
{
wxString sMenuLabel = wxStripMenuCodes(rMenuString);
) const
{
wxString sMenuLabel = wxStripMenuCodes(rMenuString);
- size_t nCount = GetMenuCount();
-
- for (
size_t i = 0; i < nCount; i
++)
+ size_t nCount = GetMenuCount()
, i
;
+ wxMenuList::const_iterator it;
+ for (
i = 0, it = m_menus.begin(); i < nCount; i++, it
++)
{
wxString sTitle = wxStripMenuCodes(m_titles[i]);
if (rMenuString == sTitle)
{
wxString sTitle = wxStripMenuCodes(m_titles[i]);
if (rMenuString == sTitle)
- return
m_menus[i]
->FindItem(rItemString);
+ return
(*it)
->FindItem(rItemString);
}
return wxNOT_FOUND;
} // end of wxMenuBar::FindMenuItem
}
return wxNOT_FOUND;
} // end of wxMenuBar::FindMenuItem
@@
-1144,13
+1149,13
@@
wxMenuItem* wxMenuBar::FindItem(
*ppItemMenu = NULL;
wxMenuItem* pItem = NULL;
*ppItemMenu = NULL;
wxMenuItem* pItem = NULL;
- size_t nCount = GetMenuCount();
-
- for (
size_t i = 0; !pItem && (i < nCount); i
++)
+ size_t nCount = GetMenuCount()
, i
;
+ wxMenuList::const_iterator it;
+ for (
i = 0, it = m_menus.begin(); !pItem && (i < nCount); i++, it
++)
{
{
- pItem =
m_menus[i]
->FindItem( nId
-
,ppItemMenu
-
);
+ pItem =
(*it)
->FindItem( nId
+ ,ppItemMenu
+ );
}
return pItem;
} // end of wxMenuBar::FindItem
}
return pItem;
} // end of wxMenuBar::FindItem
@@
-1165,14
+1170,14
@@
wxMenuItem* wxMenuBar::FindItem(
*ppItemMenu = NULL;
wxMenuItem* pItem = NULL;
*ppItemMenu = NULL;
wxMenuItem* pItem = NULL;
- size_t nCount = GetMenuCount();
-
- for (
size_t i = 0; !pItem && (i < nCount); i
++)
+ size_t nCount = GetMenuCount()
, i
;
+ wxMenuList::const_iterator it;
+ for (
i = 0, it = m_menus.begin(); !pItem && (i < nCount); i++, it
++)
{
{
- pItem =
m_menus[i]
->FindItem( nId
-
,hItem
-
,ppItemMenu
-
);
+ pItem =
(*it)
->FindItem( nId
+ ,hItem
+ ,ppItemMenu
+ );
}
return pItem;
} // end of wxMenuBar::FindItem
}
return pItem;
} // end of wxMenuBar::FindItem