Kaydet (Commit) da7b1001 authored tarafından Huzaifa Iftikhar's avatar Huzaifa Iftikhar Kaydeden (comit) Michael Stahl

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/32422Tested-by: 's avatarJenkins <ci@libreoffice.org>
Reviewed-by: 's avatarMichael Stahl <mstahl@redhat.com>
üst 4dad0c5b
......@@ -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
......
/* -*- 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
......@@ -15,6 +15,7 @@
#include "openglgdiimpl.hxx"
#include "win/salgdi.h"
#include <vcl/opengl/OpenGLContext.hxx>
#include "ControlCacheKey.hxx"
class WinOpenGLSalGraphicsImpl : public OpenGLSalGraphicsImpl
{
......
......@@ -15,6 +15,7 @@
#include "unx/salgdi.h"
#include "unx/x11/x11gdiimpl.h"
#include "openglgdiimpl.hxx"
#include "ControlCacheKey.hxx"
struct TextureCombo;
......
......@@ -37,6 +37,7 @@
#include <list>
#include <unordered_map>
#include <boost/functional/hash.hpp>
#include "ControlCacheKey.hxx"
struct ImplPostEventData;
struct ImplTimerData;
......
......@@ -27,6 +27,7 @@
#include <gdk/gdkkeysyms.h>
#include <unx/gtk/gtkframe.hxx>
#include "ControlCacheKey.hxx"
#if GTK_CHECK_VERSION(3,0,0)
......
......@@ -34,6 +34,7 @@
#include "salgeom.hxx"
#include "sallayout.hxx"
#include "vclpluginapi.h"
#include "ControlCacheKey.hxx"
#include <deque>
#include <memory>
......
......@@ -11,6 +11,7 @@
#define INCLUDED_VCL_INC_UNX_X11_X11GDIIMPL_HXX
#include "unx/pixmap.hxx"
#include "ControlCacheKey.hxx"
class ControlCacheKey;
......
......@@ -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;
......
......@@ -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;
......
......@@ -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
......
......@@ -30,6 +30,7 @@
#include "salgdiimpl.hxx"
#include <basegfx/polygon/b2dtrapezoid.hxx>
#include "ControlCacheKey.hxx"
/* From <X11/Intrinsic.h> */
typedef unsigned long Pixel;
......
......@@ -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,
......
......@@ -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";
......
......@@ -38,6 +38,7 @@
#include "outdata.hxx"
#include "win/salids.hrc"
#include "ControlCacheKey.hxx"
#if defined _MSC_VER
#ifndef min
......
......@@ -23,6 +23,7 @@
#include <vcl/gradient.hxx>
#include "svsys.h"
#include "ControlCacheKey.hxx"
class WinSalGraphics;
......
......@@ -49,7 +49,7 @@
#include <map>
#include <string>
#include <boost/optional.hpp>
#include "ControlCacheKey.hxx"
using namespace std;
typedef map< wstring, HTHEME > ThemeMap;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment