summaryrefslogtreecommitdiff
path: root/user/kwin
diff options
context:
space:
mode:
Diffstat (limited to 'user/kwin')
-rw-r--r--user/kwin/APKBUILD58
-rw-r--r--user/kwin/kwin-5.8-respect-uint.patch29
-rw-r--r--user/kwin/kwin-5.8-stop-depending-on-qt5-internals.patch479
3 files changed, 566 insertions, 0 deletions
diff --git a/user/kwin/APKBUILD b/user/kwin/APKBUILD
new file mode 100644
index 000000000..d684e442f
--- /dev/null
+++ b/user/kwin/APKBUILD
@@ -0,0 +1,58 @@
+# Contributor: A. Wilcox <awilfox@adelielinux.org>
+# Maintainer: A. Wilcox <awilfox@adelielinux.org>
+pkgname=kwin
+pkgver=5.8.7
+pkgrel=0
+pkgdesc="Modern, stylish window manager (requires OpenGL)"
+url="https://www.kde.org/"
+arch="all"
+license="LGPL-2.1"
+options="!check" # Requires accelerated X11 desktop
+depends=""
+depends_dev="qt5-qtbase-dev qt5-qtdeclarative-dev qt5-qtscript-dev kcrash-dev
+ qt5-qtx11extras-dev kconfig-dev kconfigwidgets-dev kcoreaddons-dev
+ kglobalaccel-dev ki18n-dev kinit-dev knotifications-dev kpackage-dev
+ plasma-framework-dev kwidgetsaddons-dev kwindowsystem-dev kwayland-dev
+ kiconthemes-dev kidletime-dev kcompletion-dev kdeclarative-dev kio-dev
+ kcmutils-dev ktextwidgets-dev knewstuff-dev kservice-dev kxmlgui-dev
+ kdecoration-dev kscreenlocker-dev wayland-dev mesa-dev libepoxy-dev
+ eudev-dev libdrm-dev libx11-dev libxcb-dev xcb-util-cursor-dev
+ xcb-util-image-dev xcb-util-wm-dev libxkbcommon-dev libinput-dev
+ freetype-dev fontconfig-dev qt5-qtmultimedia-dev breeze-dev"
+makedepends="$depends_dev cmake extra-cmake-modules qt5-qttools-dev python3"
+install=""
+subpackages="$pkgname-dev $pkgname-doc $pkgname-lang"
+source="http://download.kde.org/stable/plasma/$pkgver/kwin-$pkgver.tar.xz
+ kwin-5.8-stop-depending-on-qt5-internals.patch
+ kwin-5.8-respect-uint.patch"
+builddir="$srcdir/kwin-$pkgver"
+
+build() {
+ cd "$builddir"
+ if [ "$CBUILD" != "$CHOST" ]; then
+ CMAKE_CROSSOPTS="-DCMAKE_SYSTEM_NAME=Linux -DCMAKE_HOST_SYSTEM_NAME=Linux"
+ fi
+ cmake \
+ -DCMAKE_INSTALL_PREFIX=/usr \
+ -DCMAKE_INSTALL_LIBDIR=lib \
+ -DBUILD_SHARED_LIBS=True \
+ -DCMAKE_BUILD_TYPE=RelWithDebugInfo \
+ -DCMAKE_CXX_FLAGS="$CXXFLAGS" \
+ -DCMAKE_C_FLAGS="$CFLAGS" \
+ ${CMAKE_CROSSOPTS}
+ make
+}
+
+check() {
+ cd "$builddir"
+ CTEST_OUTPUT_ON_FAILURE=TRUE ctest
+}
+
+package() {
+ cd "$builddir"
+ make DESTDIR="$pkgdir" install
+}
+
+sha512sums="f1f3b01f85378e663385887add8dd5b2f40076cfc57f7cf638e83e2424fedb576b4b431b14151422ea43c535677131e61b8d9e7fe60e5a5f4ea06520c895bd1e kwin-5.8.7.tar.xz
+7186dd317204612ba26f11315238f527949424d08f32dc0dab8c1391d642529433cfd7091dc2a057fe849976dee70eed7aab3c8be55b20b8c0655da57976b48e kwin-5.8-stop-depending-on-qt5-internals.patch
+aaefa9951ec1475adf00784b202d0ca9f92a60634a869387432411e8b7928d9f10b46968998a4ada47228834e8c7f6c9bf1c8dd988673b22619e8e1295e086c7 kwin-5.8-respect-uint.patch"
diff --git a/user/kwin/kwin-5.8-respect-uint.patch b/user/kwin/kwin-5.8-respect-uint.patch
new file mode 100644
index 000000000..839d84d2e
--- /dev/null
+++ b/user/kwin/kwin-5.8-respect-uint.patch
@@ -0,0 +1,29 @@
+From 404f2675f8ca5496a5e528825078b1ce27669cd7 Mon Sep 17 00:00:00 2001
+From: Marco Martin <notmart@gmail.com>
+Date: Mon, 20 Mar 2017 17:01:39 +0100
+Subject: fix compilation on old gcc
+
+same as https://phabricator.kde.org/D5083,
+gcc 4.8.5 (opensuse leap) fails building modeltest with
+CMakeFiles/testHistoryModel.dir/modeltest.cpp.o: In function `ModelTest::data()':
+modeltest.cpp:(.text+0x5a57): undefined reference to `bool QTest::qCompare<int, unsigned int>(int const&, unsigned int const&, char const*, char const*, char const*, int)'
+---
+ kcmkwin/kwincompositing/test/modeltest.cpp | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+diff --git a/kcmkwin/kwincompositing/test/modeltest.cpp b/kcmkwin/kwincompositing/test/modeltest.cpp
+index d356b26..c077d9b 100644
+--- a/kcmkwin/kwincompositing/test/modeltest.cpp
++++ b/kcmkwin/kwincompositing/test/modeltest.cpp
+@@ -453,7 +453,7 @@ void ModelTest::data()
+ // Check that the alignment is one we know about
+ QVariant textAlignmentVariant = model->data ( model->index ( 0, 0 ), Qt::TextAlignmentRole );
+ if ( textAlignmentVariant.isValid() ) {
+- int alignment = textAlignmentVariant.toInt();
++ unsigned int alignment = textAlignmentVariant.toUInt();
+ QCOMPARE( alignment, ( alignment & ( Qt::AlignHorizontal_Mask | Qt::AlignVertical_Mask ) ) );
+ }
+
+--
+cgit v0.11.2
+
diff --git a/user/kwin/kwin-5.8-stop-depending-on-qt5-internals.patch b/user/kwin/kwin-5.8-stop-depending-on-qt5-internals.patch
new file mode 100644
index 000000000..7b77e9c57
--- /dev/null
+++ b/user/kwin/kwin-5.8-stop-depending-on-qt5-internals.patch
@@ -0,0 +1,479 @@
+From 052fa2e4ee329810f62c29e546254fb45bf8a375 Mon Sep 17 00:00:00 2001
+From: Takahiro Hashimoto <kenya888@gmail.com>
+Date: Thu, 27 Oct 2016 09:43:21 +0900
+Subject: [PATCH] [plugins/qpa] support use of modularized qtplatformsupport
+ from Qt 5.8
+
+REVIEW: 129268
+---
+ CMakeLists.txt | 9 +-
+ cmake/modules/FindQt5EventDispatcherSupport.cmake | 122 ++++++++++++++++++++++
+ cmake/modules/FindQt5FontDatabaseSupport.cmake | 122 ++++++++++++++++++++++
+ cmake/modules/FindQt5ThemeSupport.cmake | 122 ++++++++++++++++++++++
+ plugins/qpa/CMakeLists.txt | 15 ++-
+ plugins/qpa/integration.cpp | 7 ++
+ 6 files changed, 394 insertions(+), 3 deletions(-)
+ create mode 100644 cmake/modules/FindQt5EventDispatcherSupport.cmake
+ create mode 100644 cmake/modules/FindQt5FontDatabaseSupport.cmake
+ create mode 100644 cmake/modules/FindQt5ThemeSupport.cmake
+
+diff --git a/CMakeLists.txt b/CMakeLists.txt
+index 3d2883fea..bf90ab0f1 100644
+--- a/CMakeLists.txt
++++ b/CMakeLists.txt
+@@ -241,7 +241,14 @@ set_package_properties(X11_XCB PROPERTIES
+ TYPE OPTIONAL)
+
+ # dependencies for QPA plugin
+-find_package(Qt5PlatformSupport REQUIRED)
++if(Qt5Core_VERSION VERSION_LESS "5.8.0")
++ find_package(Qt5PlatformSupport REQUIRED)
++else()
++ find_package(Qt5FontDatabaseSupport REQUIRED)
++ find_package(Qt5ThemeSupport REQUIRED)
++ find_package(Qt5EventDispatcherSupport REQUIRED)
++endif()
++
+ find_package(Freetype REQUIRED)
+ set_package_properties(Freetype PROPERTIES DESCRIPTION "A font rendering engine"
+ URL "http://www.freetype.org"
+diff --git a/cmake/modules/FindQt5EventDispatcherSupport.cmake b/cmake/modules/FindQt5EventDispatcherSupport.cmake
+new file mode 100644
+index 000000000..948efe0d3
+--- /dev/null
++++ b/cmake/modules/FindQt5EventDispatcherSupport.cmake
+@@ -0,0 +1,122 @@
++#.rst:
++# FindQt5EventDispatcherSupport
++# -------
++#
++# Try to find Qt5EventDispatcherSupport on a Unix system.
++#
++# This will define the following variables:
++#
++# ``Qt5EventDispatcherSupport_FOUND``
++# True if (the requested version of) Qt5EventDispatcherSupport is available
++# ``Qt5EventDispatcherSupport_VERSION``
++# The version of Qt5EventDispatcherSupport
++# ``Qt5EventDispatcherSupport_LIBRARIES``
++# This can be passed to target_link_libraries() instead of the ``Qt5EventDispatcherSupport::Qt5EventDispatcherSupport``
++# target
++# ``Qt5EventDispatcherSupport_INCLUDE_DIRS``
++# This should be passed to target_include_directories() if the target is not
++# used for linking
++# ``Qt5EventDispatcherSupport_DEFINITIONS``
++# This should be passed to target_compile_options() if the target is not
++# used for linking
++#
++# If ``Qt5EventDispatcherSupport_FOUND`` is TRUE, it will also define the following imported target:
++#
++# ``Qt5EventDispatcherSupport::Qt5EventDispatcherSupport``
++# The Qt5EventDispatcherSupport library
++#
++# In general we recommend using the imported target, as it is easier to use.
++# Bear in mind, however, that if the target is in the link interface of an
++# exported library, it must be made available by the package config file.
++
++#=============================================================================
++# Copyright 2014 Alex Merry <alex.merry@kde.org>
++# Copyright 2014 Martin Gräßlin <mgraesslin@kde.org>
++# Copyright 2016 Takahiro Hashimoto <kenya888@gmail.com>
++#
++# Redistribution and use in source and binary forms, with or without
++# modification, are permitted provided that the following conditions
++# are met:
++#
++# 1. Redistributions of source code must retain the copyright
++# notice, this list of conditions and the following disclaimer.
++# 2. Redistributions in binary form must reproduce the copyright
++# notice, this list of conditions and the following disclaimer in the
++# documentation and/or other materials provided with the distribution.
++# 3. The name of the author may not be used to endorse or promote products
++# derived from this software without specific prior written permission.
++#
++# THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
++# IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
++# OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
++# IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
++# INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
++# NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
++# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
++# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
++# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
++# THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
++#=============================================================================
++
++if(CMAKE_VERSION VERSION_LESS 2.8.12)
++ message(FATAL_ERROR "CMake 2.8.12 is required by FindQt5EventDispatcherSupport.cmake")
++endif()
++if(CMAKE_MINIMUM_REQUIRED_VERSION VERSION_LESS 2.8.12)
++ message(AUTHOR_WARNING "Your project should require at least CMake 2.8.12 to use FindQt5EventDispatcherSupport.cmake")
++endif()
++
++# Use pkg-config to get the directories and then use these values
++# in the FIND_PATH() and FIND_LIBRARY() calls
++find_package(PkgConfig)
++pkg_check_modules(PKG_Qt5EventDispatcherSupport QUIET Qt5Gui)
++
++set(Qt5EventDispatcherSupport_DEFINITIONS ${PKG_Qt5EventDispatcherSupport_CFLAGS_OTHER})
++set(Qt5EventDispatcherSupport_VERSION ${PKG_Qt5EventDispatcherSupport_VERSION})
++
++find_path(Qt5EventDispatcherSupport_INCLUDE_DIR
++ NAMES
++ QtEventDispatcherSupport/private/qunixeventdispatcher_qpa_p.h
++ HINTS
++ ${PKG_Qt5EventDispatcherSupport_INCLUDEDIR}/QtEventDispatcherSupport/${PKG_Qt5EventDispatcherSupport_VERSION}/
++)
++find_library(Qt5EventDispatcherSupport_LIBRARY
++ NAMES
++ Qt5EventDispatcherSupport
++ HINTS
++ ${PKG_Qt5EventDispatcherSupport_LIBRARY_DIRS}
++)
++
++include(FindPackageHandleStandardArgs)
++find_package_handle_standard_args(Qt5EventDispatcherSupport
++ FOUND_VAR
++ Qt5EventDispatcherSupport_FOUND
++ REQUIRED_VARS
++ Qt5EventDispatcherSupport_LIBRARY
++ Qt5EventDispatcherSupport_INCLUDE_DIR
++ VERSION_VAR
++ Qt5EventDispatcherSupport_VERSION
++)
++
++if(Qt5EventDispatcherSupport_FOUND AND NOT TARGET Qt5EventDispatcherSupport::Qt5EventDispatcherSupport)
++ add_library(Qt5EventDispatcherSupport::Qt5EventDispatcherSupport UNKNOWN IMPORTED)
++ set_target_properties(Qt5EventDispatcherSupport::Qt5EventDispatcherSupport PROPERTIES
++ IMPORTED_LOCATION "${Qt5EventDispatcherSupport_LIBRARY}"
++ INTERFACE_COMPILE_OPTIONS "${Qt5EventDispatcherSupport_DEFINITIONS}"
++ INTERFACE_INCLUDE_DIRECTORIES "${Qt5EventDispatcherSupport_INCLUDE_DIR}"
++ )
++endif()
++
++mark_as_advanced(Qt5EventDispatcherSupport_LIBRARY Qt5EventDispatcherSupport_INCLUDE_DIR)
++
++# compatibility variables
++set(Qt5EventDispatcherSupport_LIBRARIES ${Qt5EventDispatcherSupport_LIBRARY})
++set(Qt5EventDispatcherSupport_INCLUDE_DIRS ${Qt5EventDispatcherSupport_INCLUDE_DIR})
++set(Qt5EventDispatcherSupport_VERSION_STRING ${Qt5EventDispatcherSupport_VERSION})
++
++
++include(FeatureSummary)
++set_package_properties(Qt5EventDispatcherSupport PROPERTIES
++ URL "http://www.qt.io"
++ DESCRIPTION "Qt EventDispatcherSupport module."
++)
++
+diff --git a/cmake/modules/FindQt5FontDatabaseSupport.cmake b/cmake/modules/FindQt5FontDatabaseSupport.cmake
+new file mode 100644
+index 000000000..d3e66cd30
+--- /dev/null
++++ b/cmake/modules/FindQt5FontDatabaseSupport.cmake
+@@ -0,0 +1,122 @@
++#.rst:
++# FindQt5FontDatabaseSupport
++# -------
++#
++# Try to find Qt5FontDatabaseSupport on a Unix system.
++#
++# This will define the following variables:
++#
++# ``Qt5FontDatabaseSupport_FOUND``
++# True if (the requested version of) Qt5FontDatabaseSupport is available
++# ``Qt5FontDatabaseSupport_VERSION``
++# The version of Qt5FontDatabaseSupport
++# ``Qt5FontDatabaseSupport_LIBRARIES``
++# This can be passed to target_link_libraries() instead of the ``Qt5FontDatabaseSupport::Qt5FontDatabaseSupport``
++# target
++# ``Qt5FontDatabaseSupport_INCLUDE_DIRS``
++# This should be passed to target_include_directories() if the target is not
++# used for linking
++# ``Qt5FontDatabaseSupport_DEFINITIONS``
++# This should be passed to target_compile_options() if the target is not
++# used for linking
++#
++# If ``Qt5FontDatabaseSupport_FOUND`` is TRUE, it will also define the following imported target:
++#
++# ``Qt5FontDatabaseSupport::Qt5FontDatabaseSupport``
++# The Qt5FontDatabaseSupport library
++#
++# In general we recommend using the imported target, as it is easier to use.
++# Bear in mind, however, that if the target is in the link interface of an
++# exported library, it must be made available by the package config file.
++
++#=============================================================================
++# Copyright 2014 Alex Merry <alex.merry@kde.org>
++# Copyright 2014 Martin Gräßlin <mgraesslin@kde.org>
++# Copyright 2016 Takahiro Hashimoto <kenya888@gmail.com>
++#
++# Redistribution and use in source and binary forms, with or without
++# modification, are permitted provided that the following conditions
++# are met:
++#
++# 1. Redistributions of source code must retain the copyright
++# notice, this list of conditions and the following disclaimer.
++# 2. Redistributions in binary form must reproduce the copyright
++# notice, this list of conditions and the following disclaimer in the
++# documentation and/or other materials provided with the distribution.
++# 3. The name of the author may not be used to endorse or promote products
++# derived from this software without specific prior written permission.
++#
++# THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
++# IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
++# OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
++# IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
++# INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
++# NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
++# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
++# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
++# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
++# THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
++#=============================================================================
++
++if(CMAKE_VERSION VERSION_LESS 2.8.12)
++ message(FATAL_ERROR "CMake 2.8.12 is required by FindQt5FontDatabaseSupport.cmake")
++endif()
++if(CMAKE_MINIMUM_REQUIRED_VERSION VERSION_LESS 2.8.12)
++ message(AUTHOR_WARNING "Your project should require at least CMake 2.8.12 to use FindQt5FontDatabaseSupport.cmake")
++endif()
++
++# Use pkg-config to get the directories and then use these values
++# in the FIND_PATH() and FIND_LIBRARY() calls
++find_package(PkgConfig)
++pkg_check_modules(PKG_Qt5FontDatabaseSupport QUIET Qt5Gui)
++
++set(Qt5FontDatabaseSupport_DEFINITIONS ${PKG_Qt5FontDatabaseSupport_CFLAGS_OTHER})
++set(Qt5FontDatabaseSupport_VERSION ${PKG_Qt5FontDatabaseSupport_VERSION})
++
++find_path(Qt5FontDatabaseSupport_INCLUDE_DIR
++ NAMES
++ QtFontDatabaseSupport/private/qfontconfigdatabase_p.h
++ HINTS
++ ${PKG_Qt5FontDatabaseSupport_INCLUDEDIR}/QtFontDatabaseSupport/${PKG_Qt5FontDatabaseSupport_VERSION}/
++)
++find_library(Qt5FontDatabaseSupport_LIBRARY
++ NAMES
++ Qt5FontDatabaseSupport
++ HINTS
++ ${PKG_Qt5FontDatabaseSupport_LIBRARY_DIRS}
++)
++
++include(FindPackageHandleStandardArgs)
++find_package_handle_standard_args(Qt5FontDatabaseSupport
++ FOUND_VAR
++ Qt5FontDatabaseSupport_FOUND
++ REQUIRED_VARS
++ Qt5FontDatabaseSupport_LIBRARY
++ Qt5FontDatabaseSupport_INCLUDE_DIR
++ VERSION_VAR
++ Qt5FontDatabaseSupport_VERSION
++)
++
++if(Qt5FontDatabaseSupport_FOUND AND NOT TARGET Qt5FontDatabaseSupport::Qt5FontDatabaseSupport)
++ add_library(Qt5FontDatabaseSupport::Qt5FontDatabaseSupport UNKNOWN IMPORTED)
++ set_target_properties(Qt5FontDatabaseSupport::Qt5FontDatabaseSupport PROPERTIES
++ IMPORTED_LOCATION "${Qt5FontDatabaseSupport_LIBRARY}"
++ INTERFACE_COMPILE_OPTIONS "${Qt5FontDatabaseSupport_DEFINITIONS}"
++ INTERFACE_INCLUDE_DIRECTORIES "${Qt5FontDatabaseSupport_INCLUDE_DIR}"
++ )
++endif()
++
++mark_as_advanced(Qt5FontDatabaseSupport_LIBRARY Qt5FontDatabaseSupport_INCLUDE_DIR)
++
++# compatibility variables
++set(Qt5FontDatabaseSupport_LIBRARIES ${Qt5FontDatabaseSupport_LIBRARY})
++set(Qt5FontDatabaseSupport_INCLUDE_DIRS ${Qt5FontDatabaseSupport_INCLUDE_DIR})
++set(Qt5FontDatabaseSupport_VERSION_STRING ${Qt5FontDatabaseSupport_VERSION})
++
++
++include(FeatureSummary)
++set_package_properties(Qt5FontDatabaseSupport PROPERTIES
++ URL "http://www.qt.io"
++ DESCRIPTION "Qt FontDatabaseSupport module."
++)
++
+diff --git a/cmake/modules/FindQt5ThemeSupport.cmake b/cmake/modules/FindQt5ThemeSupport.cmake
+new file mode 100644
+index 000000000..5588a7666
+--- /dev/null
++++ b/cmake/modules/FindQt5ThemeSupport.cmake
+@@ -0,0 +1,122 @@
++#.rst:
++# FindQt5ThemeSupport
++# -------
++#
++# Try to find Qt5ThemeSupport on a Unix system.
++#
++# This will define the following variables:
++#
++# ``Qt5ThemeSupport_FOUND``
++# True if (the requested version of) Qt5ThemeSupport is available
++# ``Qt5ThemeSupport_VERSION``
++# The version of Qt5ThemeSupport
++# ``Qt5ThemeSupport_LIBRARIES``
++# This can be passed to target_link_libraries() instead of the ``Qt5ThemeSupport::Qt5ThemeSupport``
++# target
++# ``Qt5ThemeSupport_INCLUDE_DIRS``
++# This should be passed to target_include_directories() if the target is not
++# used for linking
++# ``Qt5ThemeSupport_DEFINITIONS``
++# This should be passed to target_compile_options() if the target is not
++# used for linking
++#
++# If ``Qt5ThemeSupport_FOUND`` is TRUE, it will also define the following imported target:
++#
++# ``Qt5ThemeSupport::Qt5ThemeSupport``
++# The Qt5ThemeSupport library
++#
++# In general we recommend using the imported target, as it is easier to use.
++# Bear in mind, however, that if the target is in the link interface of an
++# exported library, it must be made available by the package config file.
++
++#=============================================================================
++# Copyright 2014 Alex Merry <alex.merry@kde.org>
++# Copyright 2014 Martin Gräßlin <mgraesslin@kde.org>
++# Copyright 2016 Takahiro Hashimoto <kenya888@gmail.com>
++#
++# Redistribution and use in source and binary forms, with or without
++# modification, are permitted provided that the following conditions
++# are met:
++#
++# 1. Redistributions of source code must retain the copyright
++# notice, this list of conditions and the following disclaimer.
++# 2. Redistributions in binary form must reproduce the copyright
++# notice, this list of conditions and the following disclaimer in the
++# documentation and/or other materials provided with the distribution.
++# 3. The name of the author may not be used to endorse or promote products
++# derived from this software without specific prior written permission.
++#
++# THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
++# IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
++# OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
++# IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
++# INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
++# NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
++# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
++# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
++# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
++# THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
++#=============================================================================
++
++if(CMAKE_VERSION VERSION_LESS 2.8.12)
++ message(FATAL_ERROR "CMake 2.8.12 is required by FindQt5ThemeSupport.cmake")
++endif()
++if(CMAKE_MINIMUM_REQUIRED_VERSION VERSION_LESS 2.8.12)
++ message(AUTHOR_WARNING "Your project should require at least CMake 2.8.12 to use FindQt5ThemeSupport.cmake")
++endif()
++
++# Use pkg-config to get the directories and then use these values
++# in the FIND_PATH() and FIND_LIBRARY() calls
++find_package(PkgConfig)
++pkg_check_modules(PKG_Qt5ThemeSupport QUIET Qt5Gui)
++
++set(Qt5ThemeSupport_DEFINITIONS ${PKG_Qt5ThemeSupport_CFLAGS_OTHER})
++set(Qt5ThemeSupport_VERSION ${PKG_Qt5ThemeSupport_VERSION})
++
++find_path(Qt5ThemeSupport_INCLUDE_DIR
++ NAMES
++ QtThemeSupport/private/qgenericunixthemes_p.h
++ HINTS
++ ${PKG_Qt5ThemeSupport_INCLUDEDIR}/QtThemeSupport/${PKG_Qt5ThemeSupport_VERSION}/
++)
++find_library(Qt5ThemeSupport_LIBRARY
++ NAMES
++ Qt5ThemeSupport
++ HINTS
++ ${PKG_Qt5ThemeSupport_LIBRARY_DIRS}
++)
++
++include(FindPackageHandleStandardArgs)
++find_package_handle_standard_args(Qt5ThemeSupport
++ FOUND_VAR
++ Qt5ThemeSupport_FOUND
++ REQUIRED_VARS
++ Qt5ThemeSupport_LIBRARY
++ Qt5ThemeSupport_INCLUDE_DIR
++ VERSION_VAR
++ Qt5ThemeSupport_VERSION
++)
++
++if(Qt5ThemeSupport_FOUND AND NOT TARGET Qt5ThemeSupport::Qt5ThemeSupport)
++ add_library(Qt5ThemeSupport::Qt5ThemeSupport UNKNOWN IMPORTED)
++ set_target_properties(Qt5ThemeSupport::Qt5ThemeSupport PROPERTIES
++ IMPORTED_LOCATION "${Qt5ThemeSupport_LIBRARY}"
++ INTERFACE_COMPILE_OPTIONS "${Qt5ThemeSupport_DEFINITIONS}"
++ INTERFACE_INCLUDE_DIRECTORIES "${Qt5ThemeSupport_INCLUDE_DIR}"
++ )
++endif()
++
++mark_as_advanced(Qt5ThemeSupport_LIBRARY Qt5ThemeSupport_INCLUDE_DIR)
++
++# compatibility variables
++set(Qt5ThemeSupport_LIBRARIES ${Qt5ThemeSupport_LIBRARY})
++set(Qt5ThemeSupport_INCLUDE_DIRS ${Qt5ThemeSupport_INCLUDE_DIR})
++set(Qt5ThemeSupport_VERSION_STRING ${Qt5ThemeSupport_VERSION})
++
++
++include(FeatureSummary)
++set_package_properties(Qt5ThemeSupport PROPERTIES
++ URL "http://www.qt.io"
++ DESCRIPTION "Qt ThemeSupport module."
++)
++
+diff --git a/plugins/qpa/CMakeLists.txt b/plugins/qpa/CMakeLists.txt
+index 1a91a0ff1..4094ae7d2 100644
+--- a/plugins/qpa/CMakeLists.txt
++++ b/plugins/qpa/CMakeLists.txt
+@@ -1,6 +1,5 @@
+ include_directories(${Qt5Core_PRIVATE_INCLUDE_DIRS})
+ include_directories(${Qt5Gui_PRIVATE_INCLUDE_DIRS})
+-add_definitions(-DQ_FONTCONFIGDATABASE)
+
+ set(QPA_SOURCES
+ abstractplatformcontext.cpp
+@@ -19,10 +18,22 @@ include(ECMQtDeclareLoggingCategory)
+ ecm_qt_declare_logging_category(QPA_SOURCES HEADER logging.h IDENTIFIER KWIN_QPA CATEGORY_NAME kwin_qpa_plugin DEFAULT_SEVERITY Critical)
+
+ add_library(KWinQpaPlugin MODULE ${QPA_SOURCES})
++
++if(Qt5Core_VERSION VERSION_LESS "5.8.0")
++ add_definitions(-DQ_FONTCONFIGDATABASE)
++ set(QT5PLATFORMSUPPORT_LIBS Qt5PlatformSupport::Qt5PlatformSupport)
++else()
++ set(QT5PLATFORMSUPPORT_LIBS
++ Qt5FontDatabaseSupport::Qt5FontDatabaseSupport
++ Qt5ThemeSupport::Qt5ThemeSupport
++ Qt5EventDispatcherSupport::Qt5EventDispatcherSupport
++)
++endif()
++
+ target_link_libraries(KWinQpaPlugin
+ kwin
+ KF5::WaylandClient
+- Qt5PlatformSupport::Qt5PlatformSupport
++ ${QT5PLATFORMSUPPORT_LIBS}
+ ${FONTCONFIG_LIBRARIES}
+ ${FREETYPE_LIBRARIES}
+ )
+diff --git a/plugins/qpa/integration.cpp b/plugins/qpa/integration.cpp
+index 8913bf0a1..fcca48f79 100644
+--- a/plugins/qpa/integration.cpp
++++ b/plugins/qpa/integration.cpp
+@@ -46,9 +46,16 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
+ #include <qpa/qplatforminputcontextfactory_p.h>
+ #include <qpa/qwindowsysteminterface.h>
+ #include <QtCore/private/qeventdispatcher_unix_p.h>
++
++#if QT_VERSION >= 0x050800
++#include <QtFontDatabaseSupport/private/qgenericunixfontdatabase_p.h>
++#include <QtThemeSupport/private/qgenericunixthemes_p.h>
++#include <QtEventDispatcherSupport/private/qunixeventdispatcher_qpa_p.h>
++#else
+ #include <QtPlatformSupport/private/qgenericunixfontdatabase_p.h>
+ #include <QtPlatformSupport/private/qgenericunixthemes_p.h>
+ #include <QtPlatformSupport/private/qunixeventdispatcher_qpa_p.h>
++#endif
+
+ namespace KWin
+ {