summaryrefslogtreecommitdiff
path: root/include/vcl
diff options
context:
space:
mode:
authorNoel Grandin <noel@peralex.com>2015-05-12 15:30:22 +0200
committerNoel Grandin <noel@peralex.com>2015-05-13 09:25:50 +0200
commitfacc91ab4a3f25b3290408c7083ed4c09dd8d759 (patch)
tree65062b866ac520a9f4078886ac04a20e0e492733 /include/vcl
parent96096e27457454219c6621b060e89319ceaca23c (diff)
convert FLOATWIN_POPUPMODE constants to scoped enum
Change-Id: I744d430ef6a506977eb10b892582c8969ec27524
Diffstat (limited to 'include/vcl')
-rw-r--r--include/vcl/dockwin.hxx4
-rw-r--r--include/vcl/floatwin.hxx59
-rw-r--r--include/vcl/menu.hxx3
3 files changed, 38 insertions, 28 deletions
diff --git a/include/vcl/dockwin.hxx b/include/vcl/dockwin.hxx
index a1617d111ae2..9965ebdeda8f 100644
--- a/include/vcl/dockwin.hxx
+++ b/include/vcl/dockwin.hxx
@@ -143,7 +143,7 @@ public:
void Unlock();
bool IsLocked() const { return mbLocked;}
- void StartPopupMode( ToolBox* pParentToolBox, sal_uLong nPopupModeFlags );
+ void StartPopupMode( ToolBox* pParentToolBox, FloatWinPopupFlags nPopupModeFlags );
bool IsInPopupMode() const;
void TitleButtonClick( sal_uInt16 nButton );
@@ -202,7 +202,7 @@ public:
bool IsLocked( const vcl::Window *pWin );
void StartPopupMode( ToolBox *pParentToolBox, const vcl::Window *pWin );
- void StartPopupMode( ToolBox *pParentToolBox, const vcl::Window *pWin, sal_uLong nPopupModeFlags );
+ void StartPopupMode( ToolBox *pParentToolBox, const vcl::Window *pWin, FloatWinPopupFlags nPopupModeFlags );
bool IsInPopupMode( const vcl::Window *pWin );
void EndPopupMode( const vcl::Window *pWin );
diff --git a/include/vcl/floatwin.hxx b/include/vcl/floatwin.hxx
index fb542ddffb06..d02b191aa279 100644
--- a/include/vcl/floatwin.hxx
+++ b/include/vcl/floatwin.hxx
@@ -23,6 +23,7 @@
#include <tools/solar.h>
#include <vcl/dllapi.h>
#include <vcl/syswin.hxx>
+#include <o3tl/typed_flags_set.hxx>
class ToolBox;
@@ -30,24 +31,32 @@ class ToolBox;
// - FloatingWindow-Types -
-#define FLOATWIN_POPUPMODE_ALLOWTEAROFF ((sal_uLong)0x00000001)
-#define FLOATWIN_POPUPMODE_ANIMATIONSLIDE ((sal_uLong)0x00000002)
-#define FLOATWIN_POPUPMODE_NOAUTOARRANGE ((sal_uLong)0x00000004)
-#define FLOATWIN_POPUPMODE_NOANIMATION ((sal_uLong)0x00000008)
-#define FLOATWIN_POPUPMODE_DOWN ((sal_uLong)0x00000010)
-#define FLOATWIN_POPUPMODE_UP ((sal_uLong)0x00000020)
-#define FLOATWIN_POPUPMODE_LEFT ((sal_uLong)0x00000040)
-#define FLOATWIN_POPUPMODE_RIGHT ((sal_uLong)0x00000080)
-#define FLOATWIN_POPUPMODE_NOFOCUSCLOSE ((sal_uLong)0x00000100)
-#define FLOATWIN_POPUPMODE_NOKEYCLOSE ((sal_uLong)0x00000200)
-#define FLOATWIN_POPUPMODE_NOMOUSECLOSE ((sal_uLong)0x00000400)
-#define FLOATWIN_POPUPMODE_NOMOUSERECTCLOSE ((sal_uLong)0x00000800)
-#define FLOATWIN_POPUPMODE_ALLMOUSEBUTTONCLOSE ((sal_uLong)0x00001000)
-#define FLOATWIN_POPUPMODE_NOAPPFOCUSCLOSE ((sal_uLong)0x00002000)
-#define FLOATWIN_POPUPMODE_NEWLEVEL ((sal_uLong)0x00004000)
-#define FLOATWIN_POPUPMODE_NOMOUSEUPCLOSE ((sal_uLong)0x00008000)
-#define FLOATWIN_POPUPMODE_GRABFOCUS ((sal_uLong)0x00010000)
-#define FLOATWIN_POPUPMODE_NOHORZPLACEMENT ((sal_uLong)0x00020000)
+enum class FloatWinPopupFlags
+{
+ NONE = 0x000000,
+ AllowTearOff = 0x000001,
+ AnimationSlide = 0x000002,
+ NoAutoArrange = 0x000004,
+ NoAnimation = 0x000008,
+ Down = 0x000010,
+ Up = 0x000020,
+ Left = 0x000040,
+ Right = 0x000080,
+ NoFocusClose = 0x000100,
+ NoKeyClose = 0x000200,
+ NoMouseClose = 0x000400,
+ NoMouseRectClose = 0x000800,
+ AllMouseButtonClose = 0x001000,
+ NoAppFocusClose = 0x002000,
+ NewLevel = 0x004000,
+ NoMouseUpClose = 0x008000,
+ GrabFocus = 0x010000,
+ NoHorzPlacement = 0x020000,
+};
+namespace o3tl
+{
+ template<> struct typed_flags<FloatWinPopupFlags> : is_typed_flags<FloatWinPopupFlags, 0x03ffff> {};
+}
#define FLOATWIN_POPUPMODEEND_CANCEL ((sal_uInt16)0x0001)
#define FLOATWIN_POPUPMODEEND_TEAROFF ((sal_uInt16)0x0002)
@@ -78,7 +87,7 @@ private:
ImplData* mpImplData;
Rectangle maFloatRect;
ImplSVEvent * mnPostId;
- sal_uLong mnPopupModeFlags;
+ FloatWinPopupFlags mnPopupModeFlags;
sal_uInt16 mnTitle;
sal_uInt16 mnOldTitle;
bool mbInPopupMode;
@@ -110,7 +119,7 @@ public:
SAL_DLLPRIVATE void ImplSetMouseDown() { mbMouseDown = true; }
SAL_DLLPRIVATE bool ImplIsMouseDown() const { return mbMouseDown; }
SAL_DLLPRIVATE static Point ImplCalcPos( vcl::Window* pWindow,
- const Rectangle& rRect, sal_uLong nFlags,
+ const Rectangle& rRect, FloatWinPopupFlags nFlags,
sal_uInt16& rArrangeIndex );
SAL_DLLPRIVATE void ImplEndPopupMode( sal_uInt16 nFlags = 0, sal_uLong nFocusId = 0 );
SAL_DLLPRIVATE Rectangle& ImplGetItemEdgeClipRect();
@@ -133,12 +142,12 @@ public:
void SetTitleType( sal_uInt16 nTitle );
sal_uInt16 GetTitleType() const { return mnTitle; }
- void StartPopupMode( const Rectangle& rRect, sal_uLong nFlags = 0 );
- void StartPopupMode( ToolBox* pBox, sal_uLong nFlags = 0 );
+ void StartPopupMode( const Rectangle& rRect, FloatWinPopupFlags nFlags = FloatWinPopupFlags::NONE );
+ void StartPopupMode( ToolBox* pBox, FloatWinPopupFlags nFlags = FloatWinPopupFlags::NONE );
void EndPopupMode( sal_uInt16 nFlags = 0 );
void AddPopupModeWindow( vcl::Window* pWindow );
- sal_uLong GetPopupModeFlags() const { return mnPopupModeFlags; }
- void SetPopupModeFlags( sal_uLong nFlags ) { mnPopupModeFlags = nFlags; }
+ FloatWinPopupFlags GetPopupModeFlags() const { return mnPopupModeFlags; }
+ void SetPopupModeFlags( FloatWinPopupFlags nFlags ) { mnPopupModeFlags = nFlags; }
bool IsInPopupMode() const { return mbPopupMode; }
bool IsInCleanUp() const { return mbInCleanUp; }
bool IsPopupModeCanceled() const { return mbPopupModeCanceled; }
@@ -149,7 +158,7 @@ public:
bool GrabsFocus() const { return mbGrabFocus; }
- static Point CalcFloatingPosition( vcl::Window* pWindow, const Rectangle& rRect, sal_uLong nFlags, sal_uInt16& rArrangeIndex );
+ static Point CalcFloatingPosition( vcl::Window* pWindow, const Rectangle& rRect, FloatWinPopupFlags nFlags, sal_uInt16& rArrangeIndex );
};
#endif // INCLUDED_VCL_FLOATWIN_HXX
diff --git a/include/vcl/menu.hxx b/include/vcl/menu.hxx
index 7c570f0f646b..24c716daa466 100644
--- a/include/vcl/menu.hxx
+++ b/include/vcl/menu.hxx
@@ -48,6 +48,7 @@ namespace vcl { class Window; }
class SalMenu;
class IMenuBarWindow;
struct SystemMenuData;
+enum class FloatWinPopupFlags;
namespace com {
namespace sun {
@@ -503,7 +504,7 @@ private:
SAL_DLLPRIVATE MenuFloatingWindow * ImplGetFloatingWindow() const;
protected:
- SAL_DLLPRIVATE sal_uInt16 ImplExecute( vcl::Window* pWindow, const Rectangle& rRect, sal_uLong nPopupFlags, Menu* pStaredFrom, bool bPreSelectFirst );
+ SAL_DLLPRIVATE sal_uInt16 ImplExecute( vcl::Window* pWindow, const Rectangle& rRect, FloatWinPopupFlags nPopupFlags, Menu* pStaredFrom, bool bPreSelectFirst );
SAL_DLLPRIVATE long ImplCalcHeight( sal_uInt16 nEntries ) const;
SAL_DLLPRIVATE sal_uInt16 ImplCalcVisEntries( long nMaxHeight, sal_uInt16 nStartEntry = 0, sal_uInt16* pLastVisible = NULL ) const;