summaryrefslogtreecommitdiff
path: root/vcl/source/window/menu.cxx
diff options
context:
space:
mode:
authorJan Holesovsky <kendy@collabora.com>2014-09-09 10:10:53 +0200
committerJan Holesovsky <kendy@collabora.com>2014-09-09 11:01:53 +0200
commite2e2b03b185639e72669b50b674e5feec5e706cd (patch)
tree7186c98a0bd5fb99bdeb4d527e914f535a7a595b /vcl/source/window/menu.cxx
parent2be527134fc132fcb6d294b1863823064282f061 (diff)
vcl: Virtual functions do not work in constructors, avoid IsMenuBar() there.
Actually, this cleans this up further - Menu is an abstract class, so make its constructor protected; which allows us to move the native menu construction accordingly. Change-Id: I774cf4ed0cd62b54074fa287d1a7192aced7efee
Diffstat (limited to 'vcl/source/window/menu.cxx')
-rw-r--r--vcl/source/window/menu.cxx75
1 files changed, 38 insertions, 37 deletions
diff --git a/vcl/source/window/menu.cxx b/vcl/source/window/menu.cxx
index 56a1d5df4d46..9e818105120c 100644
--- a/vcl/source/window/menu.cxx
+++ b/vcl/source/window/menu.cxx
@@ -111,8 +111,22 @@ static void ImplSetMenuItemData( MenuItemData* pData )
}
Menu::Menu()
+ : mpFirstDel(NULL),
+ pItemList(new MenuItemList),
+ pLogo(NULL),
+ pStartedFrom(NULL),
+ pWindow(NULL),
+ nEventId(0),
+ mnHighlightedItemPos(ITEMPOS_INVALID),
+ nMenuFlags(0),
+ nDefaultItem(0),
+ nSelectedId(0),
+ bCanceled(false),
+ bInCallback(false),
+ bKilled(false),
+ mpLayoutData(NULL),
+ mpSalMenu(NULL)
{
- ImplInit();
}
Menu::~Menu()
@@ -161,27 +175,6 @@ Menu::~Menu()
ImplSetSalMenu( NULL );
}
-void Menu::ImplInit()
-{
- mnHighlightedItemPos = ITEMPOS_INVALID;
- mpSalMenu = NULL;
- nMenuFlags = 0;
- nDefaultItem = 0;
- nSelectedId = 0;
- pItemList = new MenuItemList;
- pLogo = NULL;
- pStartedFrom = NULL;
- pWindow = NULL;
- nEventId = 0;
- bCanceled = false;
- bInCallback = false;
- bKilled = false;
- mpLayoutData = NULL;
- mpFirstDel = NULL; // Dtor notification list
- // Native-support: returns NULL if not supported
- mpSalMenu = ImplGetSVData()->mpDefInst->CreateMenu(IsMenuBar(), this);
-}
-
void Menu::ImplLoadRes( const ResId& rResId )
{
ResMgr* pMgr = rResId.GetResMgr();
@@ -2472,21 +2465,25 @@ void Menu::HighlightItem( sal_uInt16 nItemPos )
// - MenuBar -
-MenuBar::MenuBar() : Menu()
+MenuBar::MenuBar()
+ : Menu(),
+ mbCloserVisible(false),
+ mbFloatBtnVisible(false),
+ mbHideBtnVisible(false),
+ mbDisplayable(true)
{
- mbDisplayable = true;
- mbCloserVisible = false;
- mbFloatBtnVisible = false;
- mbHideBtnVisible = false;
+ mpSalMenu = ImplGetSVData()->mpDefInst->CreateMenu(true, this);
}
-MenuBar::MenuBar( const MenuBar& rMenu ) : Menu()
+MenuBar::MenuBar( const MenuBar& rMenu )
+ : Menu(),
+ mbCloserVisible(false),
+ mbFloatBtnVisible(false),
+ mbHideBtnVisible(false),
+ mbDisplayable(true)
{
- mbDisplayable = true;
- mbCloserVisible = false;
- mbFloatBtnVisible = false;
- mbHideBtnVisible = false;
- *this = rMenu;
+ mpSalMenu = ImplGetSVData()->mpDefInst->CreateMenu(true, this);
+ *this = rMenu;
}
MenuBar::~MenuBar()
@@ -2694,19 +2691,23 @@ bool MenuBar::HandleMenuButtonEvent( Menu *, sal_uInt16 i_nButtonId ) const
// bool PopupMenu::bAnyPopupInExecute = false;
PopupMenu::PopupMenu()
+ : pRefAutoSubMenu(NULL)
{
- pRefAutoSubMenu = NULL;
+ mpSalMenu = ImplGetSVData()->mpDefInst->CreateMenu(false, this);
}
PopupMenu::PopupMenu( const ResId& rResId )
+ : pRefAutoSubMenu(NULL)
{
- pRefAutoSubMenu = NULL;
+ mpSalMenu = ImplGetSVData()->mpDefInst->CreateMenu(false, this);
ImplLoadRes( rResId );
}
-PopupMenu::PopupMenu( const PopupMenu& rMenu ) : Menu()
+PopupMenu::PopupMenu( const PopupMenu& rMenu )
+ : Menu(),
+ pRefAutoSubMenu(NULL)
{
- pRefAutoSubMenu = NULL;
+ mpSalMenu = ImplGetSVData()->mpDefInst->CreateMenu(false, this);
*this = rMenu;
}