diff options
author | Jan Holesovsky <kendy@collabora.com> | 2014-09-09 10:10:53 +0200 |
---|---|---|
committer | Jan Holesovsky <kendy@collabora.com> | 2014-09-09 11:01:53 +0200 |
commit | e2e2b03b185639e72669b50b674e5feec5e706cd (patch) | |
tree | 7186c98a0bd5fb99bdeb4d527e914f535a7a595b /vcl/source/window/menu.cxx | |
parent | 2be527134fc132fcb6d294b1863823064282f061 (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.cxx | 75 |
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; } |