[Libreoffice-commits] core.git: include/vcl vcl/inc vcl/opengl vcl/unx vcl/win

Huzaifa Iftikhar huzaifa3196 at gmail.com
Wed Jan 4 16:02:48 UTC 2017


 include/vcl/salnativewidgets.hxx      |   53 ----------------------
 vcl/inc/ControlCacheKey.hxx           |   79 ++++++++++++++++++++++++++++++++++
 vcl/inc/opengl/win/gdiimpl.hxx        |    1 
 vcl/inc/opengl/x11/gdiimpl.hxx        |    1 
 vcl/inc/svdata.hxx                    |    1 
 vcl/inc/unx/gtk/gtkgdi.hxx            |    1 
 vcl/inc/unx/salgdi.h                  |    1 
 vcl/inc/unx/x11/x11gdiimpl.h          |    1 
 vcl/opengl/win/gdiimpl.cxx            |    1 
 vcl/opengl/x11/gdiimpl.cxx            |    1 
 vcl/unx/generic/gdi/gdiimpl.cxx       |    1 
 vcl/unx/generic/gdi/gdiimpl.hxx       |    1 
 vcl/unx/generic/gdi/salgdi2.cxx       |    1 
 vcl/unx/gtk/salnativewidgets-gtk.cxx  |    1 
 vcl/win/gdi/gdiimpl.cxx               |    1 
 vcl/win/gdi/gdiimpl.hxx               |    1 
 vcl/win/gdi/salnativewidgets-luna.cxx |    2 
 17 files changed, 94 insertions(+), 54 deletions(-)

New commits:
commit da7b10018433946dd0e0125ec5316dbe8c8b683c
Author: Huzaifa Iftikhar <huzaifa3196 at gmail.com>
Date:   Mon Dec 26 02:51:03 2016 +0530

    tdf#97228 Moved class ControlCacheKey in a seperate include file.
    
    class ControlCacheKey defined in include/vcl/salnativewidgets.hxx is used
    only by vcl therefore it is moved to a seperate include file named
    ControlCacheKey.hxx which is inside vcl/inc/ControlCacheKey.hxx.
    
    This header file contains the definition of the the class ControlCacheKey.
    
    Since this class uses an object of another class named Size which is
    defined in gen.hxx therefore this is included in ControlCacheKey.hxx.
    
    All the files that references the class ControlCacheKey includes
    ControlCacheKey.hxx with the syntax: #include "ControlCacheKey.hxx"
    
    Change-Id: I7d7b3e1cf6950a953e6bbed670c1914826b2bacd
    Reviewed-on: https://gerrit.libreoffice.org/32422
    Tested-by: Jenkins <ci at libreoffice.org>
    Reviewed-by: Michael Stahl <mstahl at redhat.com>

diff --git a/include/vcl/salnativewidgets.hxx b/include/vcl/salnativewidgets.hxx
index 5d5bd1c..30997a9 100644
--- a/include/vcl/salnativewidgets.hxx
+++ b/include/vcl/salnativewidgets.hxx
@@ -226,59 +226,6 @@ namespace o3tl
     template<> struct typed_flags<ControlState> : is_typed_flags<ControlState, 0xc06f> {};
 }
 
-class ControlCacheKey
-{
-public:
-    ControlType mnType;
-    ControlPart mnPart;
-    ControlState mnState;
-    Size maSize;
-
-    ControlCacheKey(ControlType nType, ControlPart nPart, ControlState nState, const Size& rSize)
-        : mnType(nType)
-        , mnPart(nPart)
-        , mnState(nState)
-        , maSize(rSize)
-    {}
-
-    bool operator==(ControlCacheKey const& aOther) const
-    {
-        return mnType == aOther.mnType
-            && mnPart == aOther.mnPart
-            && mnState == aOther.mnState
-            && maSize.Width() == aOther.maSize.Width()
-            && maSize.Height() == aOther.maSize.Height();
-    }
-
-    bool canCacheControl()
-    {
-        switch(mnType)
-        {
-            case ControlType::Checkbox:
-            case ControlType::Radiobutton:
-            case ControlType::ListNode:
-            case ControlType::Slider:
-            case ControlType::Progress:
-            // FIXME: these guys have complex state hidden in ImplControlValue
-            // structs which affects rendering, needs to be a and needs to be
-            // part of the key to our cache.
-            case ControlType::Spinbox:
-            case ControlType::SpinButtons:
-            case ControlType::TabItem:
-                return false;
-
-            case ControlType::Menubar:
-                if (mnPart == ControlPart::Entire)
-                    return false;
-                break;
-
-            default:
-                break;
-        }
-        return true;
-    }
-};
-
 /* ButtonValue:
  *
  *   Identifies the tri-state value options
diff --git a/vcl/inc/ControlCacheKey.hxx b/vcl/inc/ControlCacheKey.hxx
new file mode 100644
index 0000000..20baa6e
--- /dev/null
+++ b/vcl/inc/ControlCacheKey.hxx
@@ -0,0 +1,79 @@
+/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
+/*
+ * This file is part of the LibreOffice project.
+ *
+ * This Source Code Form is subject to the terms of the Mozilla Public
+ * License, v. 2.0. If a copy of the MPL was not distributed with this
+ * file, You can obtain one at http://mozilla.org/MPL/2.0/.
+ *
+ * This file incorporates work covered by the following license notice:
+ *
+ *   Licensed to the Apache Software Foundation (ASF) under one or more
+ *   contributor license agreements. See the NOTICE file distributed
+ *   with this work for additional information regarding copyright
+ *   ownership. The ASF licenses this file to you under the Apache
+ *   License, Version 2.0 (the "License"); you may not use this file
+ *   except in compliance with the License. You may obtain a copy of
+ *   the License at http://www.apache.org/licenses/LICENSE-2.0 .
+ */
+
+#ifndef INCLUDED_VCL_INC_CONTROLCACHEKEY_HXX
+#define INCLUDED_VCL_INC_CONTROLCACHEKEY_HXX
+
+#include <tools/gen.hxx>
+#include <vcl/salnativewidgets.hxx>
+
+class ControlCacheKey
+{
+public:
+    ControlType mnType;
+    ControlPart mnPart;
+    ControlState mnState;
+    Size maSize;
+
+    ControlCacheKey(ControlType nType, ControlPart nPart, ControlState nState, const Size& rSize)
+        : mnType(nType)
+        , mnPart(nPart)
+        , mnState(nState)
+        , maSize(rSize)
+    {}
+
+    bool operator==(ControlCacheKey const& aOther) const
+    {
+        return mnType == aOther.mnType
+            && mnPart == aOther.mnPart
+            && mnState == aOther.mnState
+            && maSize.Width() == aOther.maSize.Width()
+            && maSize.Height() == aOther.maSize.Height();
+    }
+
+    bool canCacheControl()
+    {
+        switch(mnType)
+        {
+            case ControlType::Checkbox:
+            case ControlType::Radiobutton:
+            case ControlType::ListNode:
+            case ControlType::Slider:
+            case ControlType::Progress:
+            // FIXME: these guys have complex state hidden in ImplControlValue
+            // structs which affects rendering, needs to be a and needs to be
+            // part of the key to our cache.
+            case ControlType::Spinbox:
+            case ControlType::SpinButtons:
+            case ControlType::TabItem:
+                return false;
+
+            case ControlType::Menubar:
+                if (mnPart == ControlPart::Entire)
+                    return false;
+                break;
+
+            default:
+                break;
+        }
+        return true;
+    }
+};
+
+#endif // INCLUDED_VCL_INC_CONTROLCACHEKEY_HXX
\ No newline at end of file
diff --git a/vcl/inc/opengl/win/gdiimpl.hxx b/vcl/inc/opengl/win/gdiimpl.hxx
index 1ea54be..374d6ff 100644
--- a/vcl/inc/opengl/win/gdiimpl.hxx
+++ b/vcl/inc/opengl/win/gdiimpl.hxx
@@ -15,6 +15,7 @@
 #include "openglgdiimpl.hxx"
 #include "win/salgdi.h"
 #include <vcl/opengl/OpenGLContext.hxx>
+#include "ControlCacheKey.hxx"
 
 class WinOpenGLSalGraphicsImpl : public OpenGLSalGraphicsImpl
 {
diff --git a/vcl/inc/opengl/x11/gdiimpl.hxx b/vcl/inc/opengl/x11/gdiimpl.hxx
index 646b7a6..9dacf6d 100644
--- a/vcl/inc/opengl/x11/gdiimpl.hxx
+++ b/vcl/inc/opengl/x11/gdiimpl.hxx
@@ -15,6 +15,7 @@
 #include "unx/salgdi.h"
 #include "unx/x11/x11gdiimpl.h"
 #include "openglgdiimpl.hxx"
+#include "ControlCacheKey.hxx"
 
 struct TextureCombo;
 
diff --git a/vcl/inc/svdata.hxx b/vcl/inc/svdata.hxx
index 8135651..a8b3ccb 100644
--- a/vcl/inc/svdata.hxx
+++ b/vcl/inc/svdata.hxx
@@ -37,6 +37,7 @@
 #include <list>
 #include <unordered_map>
 #include <boost/functional/hash.hpp>
+#include "ControlCacheKey.hxx"
 
 struct ImplPostEventData;
 struct ImplTimerData;
diff --git a/vcl/inc/unx/gtk/gtkgdi.hxx b/vcl/inc/unx/gtk/gtkgdi.hxx
index f780964..23e423b 100644
--- a/vcl/inc/unx/gtk/gtkgdi.hxx
+++ b/vcl/inc/unx/gtk/gtkgdi.hxx
@@ -27,6 +27,7 @@
 #include <gdk/gdkkeysyms.h>
 
 #include <unx/gtk/gtkframe.hxx>
+#include "ControlCacheKey.hxx"
 
 #if GTK_CHECK_VERSION(3,0,0)
 
diff --git a/vcl/inc/unx/salgdi.h b/vcl/inc/unx/salgdi.h
index ef7ad2c..fb7d0fe 100644
--- a/vcl/inc/unx/salgdi.h
+++ b/vcl/inc/unx/salgdi.h
@@ -34,6 +34,7 @@
 #include "salgeom.hxx"
 #include "sallayout.hxx"
 #include "vclpluginapi.h"
+#include "ControlCacheKey.hxx"
 
 #include <deque>
 #include <memory>
diff --git a/vcl/inc/unx/x11/x11gdiimpl.h b/vcl/inc/unx/x11/x11gdiimpl.h
index c504364..9d91ad2 100644
--- a/vcl/inc/unx/x11/x11gdiimpl.h
+++ b/vcl/inc/unx/x11/x11gdiimpl.h
@@ -11,6 +11,7 @@
 #define INCLUDED_VCL_INC_UNX_X11_X11GDIIMPL_HXX
 
 #include "unx/pixmap.hxx"
+#include "ControlCacheKey.hxx"
 
 class ControlCacheKey;
 
diff --git a/vcl/opengl/win/gdiimpl.cxx b/vcl/opengl/win/gdiimpl.cxx
index ce61676..4209e0c 100644
--- a/vcl/opengl/win/gdiimpl.cxx
+++ b/vcl/opengl/win/gdiimpl.cxx
@@ -17,6 +17,7 @@
 #include <win/salframe.h>
 #include <win/salinst.h>
 #include <epoxy/wgl.h>
+#include "ControlCacheKey.hxx"
 
 static std::vector<HGLRC> g_vShareList;
 static bool g_bAnyCurrent;
diff --git a/vcl/opengl/x11/gdiimpl.cxx b/vcl/opengl/x11/gdiimpl.cxx
index 164fc71..c6807de 100644
--- a/vcl/opengl/x11/gdiimpl.cxx
+++ b/vcl/opengl/x11/gdiimpl.cxx
@@ -30,6 +30,7 @@
 #include <vcl/opengl/OpenGLHelper.hxx>
 
 #include <o3tl/lru_map.hxx>
+#include "ControlCacheKey.hxx"
 
 static std::vector<GLXContext> g_vShareList;
 static bool g_bAnyCurrent;
diff --git a/vcl/unx/generic/gdi/gdiimpl.cxx b/vcl/unx/generic/gdi/gdiimpl.cxx
index e929f6b..5e44e4b 100644
--- a/vcl/unx/generic/gdi/gdiimpl.cxx
+++ b/vcl/unx/generic/gdi/gdiimpl.cxx
@@ -48,6 +48,7 @@
 #include "basegfx/matrix/b2dhommatrixtools.hxx"
 #include "basegfx/polygon/b2dpolypolygoncutter.hxx"
 #include "basegfx/polygon/b2dtrapezoid.hxx"
+#include "ControlCacheKey.hxx"
 
 #undef SALGDI2_TESTTRANS
 
diff --git a/vcl/unx/generic/gdi/gdiimpl.hxx b/vcl/unx/generic/gdi/gdiimpl.hxx
index b277b9a..2ad9b96 100644
--- a/vcl/unx/generic/gdi/gdiimpl.hxx
+++ b/vcl/unx/generic/gdi/gdiimpl.hxx
@@ -30,6 +30,7 @@
 #include "salgdiimpl.hxx"
 
 #include <basegfx/polygon/b2dtrapezoid.hxx>
+#include "ControlCacheKey.hxx"
 
 /* From <X11/Intrinsic.h> */
 typedef unsigned long Pixel;
diff --git a/vcl/unx/generic/gdi/salgdi2.cxx b/vcl/unx/generic/gdi/salgdi2.cxx
index a600c31..9b2b3c9 100644
--- a/vcl/unx/generic/gdi/salgdi2.cxx
+++ b/vcl/unx/generic/gdi/salgdi2.cxx
@@ -38,6 +38,7 @@
 
 #include <vcl/bitmapaccess.hxx>
 #include <outdata.hxx>
+#include "ControlCacheKey.hxx"
 
 void X11SalGraphics::CopyScreenArea( Display* pDisplay,
                                      Drawable aSrc, SalX11Screen nXScreenSrc, int nSrcDepth,
diff --git a/vcl/unx/gtk/salnativewidgets-gtk.cxx b/vcl/unx/gtk/salnativewidgets-gtk.cxx
index 8d0c96c..5e07ade 100644
--- a/vcl/unx/gtk/salnativewidgets-gtk.cxx
+++ b/vcl/unx/gtk/salnativewidgets-gtk.cxx
@@ -44,6 +44,7 @@
 #include <vcl/decoview.hxx>
 
 #include <vcl/opengl/OpenGLHelper.hxx>
+#include "ControlCacheKey.hxx"
 
 typedef struct _cairo_font_options cairo_font_options_t;
 const char* const tabPrelitDataName="libreoffice-tab-is-prelit";
diff --git a/vcl/win/gdi/gdiimpl.cxx b/vcl/win/gdi/gdiimpl.cxx
index 9c05466..250c2c8 100644
--- a/vcl/win/gdi/gdiimpl.cxx
+++ b/vcl/win/gdi/gdiimpl.cxx
@@ -38,6 +38,7 @@
 
 #include "outdata.hxx"
 #include "win/salids.hrc"
+#include "ControlCacheKey.hxx"
 
 #if defined _MSC_VER
 #ifndef min
diff --git a/vcl/win/gdi/gdiimpl.hxx b/vcl/win/gdi/gdiimpl.hxx
index e8235c7..e6a48a1 100644
--- a/vcl/win/gdi/gdiimpl.hxx
+++ b/vcl/win/gdi/gdiimpl.hxx
@@ -23,6 +23,7 @@
 #include <vcl/gradient.hxx>
 
 #include "svsys.h"
+#include "ControlCacheKey.hxx"
 
 class WinSalGraphics;
 
diff --git a/vcl/win/gdi/salnativewidgets-luna.cxx b/vcl/win/gdi/salnativewidgets-luna.cxx
index 07586b4..f5a17ef 100644
--- a/vcl/win/gdi/salnativewidgets-luna.cxx
+++ b/vcl/win/gdi/salnativewidgets-luna.cxx
@@ -49,7 +49,7 @@
 #include <map>
 #include <string>
 #include <boost/optional.hpp>
-
+#include "ControlCacheKey.hxx"
 using namespace std;
 
 typedef map< wstring, HTHEME > ThemeMap;


More information about the Libreoffice-commits mailing list