From 13b4b7c4a8f33158744d6ec34e60d0678f3b9c6684f6f577471750685df72362 Mon Sep 17 00:00:00 2001 From: Hrvoje Senjan Date: Sat, 11 Jun 2016 16:08:40 +0000 Subject: [PATCH] OBS-URL: https://build.opensuse.org/package/show/KDE:Frameworks5/breeze-gtk?expand=0&rev=13 --- ...me-version-depending-on-present-libg.patch | 624 ++++++++++++++++++ breeze-gtk.changes | 8 + breeze-gtk.spec | 4 + 3 files changed, 636 insertions(+) create mode 100644 Install-GTK3-theme-version-depending-on-present-libg.patch diff --git a/Install-GTK3-theme-version-depending-on-present-libg.patch b/Install-GTK3-theme-version-depending-on-present-libg.patch new file mode 100644 index 0000000..74b3e7e --- /dev/null +++ b/Install-GTK3-theme-version-depending-on-present-libg.patch @@ -0,0 +1,624 @@ +From d60226d8c8c29c01f5c5a3447d6b42370e29f658 Mon Sep 17 00:00:00 2001 +From: Hrvoje Senjan +Date: Sat, 11 Jun 2016 18:05:14 +0200 +Subject: [PATCH 1/1] Install GTK3 theme version depending on present libgtk3 + version + +--- + Breeze-gtk/CMakeLists.txt | 8 +- + CMakeLists.txt | 7 +- + cmake/FindGTK3.cmake | 563 ++++++++++++++++++++++++++++++++++++++++++++++ + 3 files changed, 572 insertions(+), 6 deletions(-) + create mode 100644 cmake/FindGTK3.cmake + +diff --git a/Breeze-gtk/CMakeLists.txt b/Breeze-gtk/CMakeLists.txt +index 957665f..a1de41c 100644 +--- a/Breeze-gtk/CMakeLists.txt ++++ b/Breeze-gtk/CMakeLists.txt +@@ -3,8 +3,10 @@ install(DIRECTORY gtk-2.0 DESTINATION ${KDE_INSTALL_FULL_DATAROOTDIR}/themes/Bre + install(DIRECTORY assets DESTINATION ${KDE_INSTALL_FULL_DATAROOTDIR}/themes/Breeze + ${directory_EXCLUDES}) + +-if (WITH_GTK3_VERSION VERSION_LESS "3.20") +-install(FILES gtk-3.18/gtk.css DESTINATION ${KDE_INSTALL_FULL_DATAROOTDIR}/themes/Breeze/gtk-3.0/) +-else() ++if (WITH_GTK3_VERSION VERSION_EQUAL "3.20") + install(FILES gtk-3.20/gtk.css DESTINATION ${KDE_INSTALL_FULL_DATAROOTDIR}/themes/Breeze/gtk-3.0/) ++elseif (WITH_GTK3_VERSION VERSION_EQUAL "3.18") ++install(FILES gtk-3.18/gtk.css DESTINATION ${KDE_INSTALL_FULL_DATAROOTDIR}/themes/Breeze/gtk-3.0/) ++elseif (WITH_GTK3_VERSION VERSION_EQUAL "3.18") ++install(FILES gtk-3.0/gtk.css DESTINATION ${KDE_INSTALL_FULL_DATAROOTDIR}/themes/Breeze/gtk-3.0/) + endif() +diff --git a/CMakeLists.txt b/CMakeLists.txt +index c5abafe..bcca32b 100644 +--- a/CMakeLists.txt ++++ b/CMakeLists.txt +@@ -7,12 +7,13 @@ cmake_minimum_required(VERSION 2.8.12) + find_package(ECM 0.0.9 REQUIRED NO_MODULE) + include(FeatureSummary) + +-set(WITH_GTK3_VERSION 3.18 CACHE STRING +- "Use the theme for the specified GTK+3 version (default: 3.18)") +- + set(CMAKE_MODULE_PATH ${ECM_MODULE_PATH} ${ECM_KDE_MODULE_DIR} "${CMAKE_SOURCE_DIR}/cmake") + include(KDEInstallDirs) + ++find_package(GTK3 3.0 REQUIRED gtk) ++set(WITH_GTK3_VERSION ${GTK3_MAJOR_VERSION}.${GTK3_MINOR_VERSION} CACHE STRING ++ "Use the theme for the specified GTK+3 version (default: 3.18)") ++ + # Exclude these patterns when installing directories as they have no use + # in production. + set(directory_EXCLUDES +diff --git a/cmake/FindGTK3.cmake b/cmake/FindGTK3.cmake +new file mode 100644 +index 0000000..9017c07 +--- /dev/null ++++ b/cmake/FindGTK3.cmake +@@ -0,0 +1,563 @@ ++# - FindGTK3.cmake ++# This module can find the GTK3 widget libraries and several of its other ++# optional components like gtkmm, glade, and glademm. ++# ++# NOTE: If you intend to use version checking, CMake 2.6.2 or later is ++# required. ++# ++# Specify one or more of the following components ++# as you call this find module. See example below. ++# ++# gtk ++# gtkmm ++# glade ++# glademm ++# ++# The following variables will be defined for your use ++# ++# GTK3_FOUND - Were all of your specified components found? ++# GTK3_INCLUDE_DIRS - All include directories ++# GTK3_LIBRARIES - All libraries ++# ++# GTK3_VERSION - The version of GTK3 found (x.y.z) ++# GTK3_MAJOR_VERSION - The major version of GTK3 ++# GTK3_MINOR_VERSION - The minor version of GTK3 ++# GTK3_PATCH_VERSION - The patch version of GTK3 ++# ++# Optional variables you can define prior to calling this module: ++# ++# GTK3_DEBUG - Enables verbose debugging of the module ++# GTK3_SKIP_MARK_AS_ADVANCED - Disable marking cache variables as advanced ++# GTK3_ADDITIONAL_SUFFIXES - Allows defining additional directories to ++# search for include files ++# ++#================= ++# Example Usage: ++# ++# Call find_package() once, here are some examples to pick from: ++# ++# Require GTK 3.0 or later ++# find_package(GTK3 3.0 REQUIRED gtk) ++# ++# if(GTK3_FOUND) ++# include_directories(${GTK3_INCLUDE_DIRS}) ++# add_executable(mygui mygui.cc) ++# target_link_libraries(mygui ${GTK3_LIBRARIES}) ++# endif() ++# ++ ++#============================================================================= ++# Copyright 2009 Kitware, Inc. ++# Copyright 2008-2009 Philip Lowman ++# ++# Distributed under the OSI-approved BSD License (the "License"); ++# see accompanying file Copyright.txt for details. ++# ++# This software is distributed WITHOUT ANY WARRANTY; without even the ++# implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. ++# See the License for more information. ++#============================================================================= ++# (To distribute this file outside of CMake, substitute the full ++# License text for the above reference.) ++ ++ ++# Version 0.1 (5/13/2011) ++# * First cut at a GTK3 version (Heavily derived from ++# FindGTK2.cmake) ++ ++ ++#============================================================= ++# _GTK3_GET_VERSION ++# Internal function to parse the version number in gtkversion.h ++# _OUT_major = Major version number ++# _OUT_minor = Minor version number ++# _OUT_micro = Micro version number ++# _gtkversion_hdr = Header file to parse ++#============================================================= ++function(_GTK3_GET_VERSION _OUT_major _OUT_minor _OUT_micro _gtkversion_hdr) ++ file(READ ${_gtkversion_hdr} _contents) ++ if(_contents) ++ string(REGEX REPLACE ".*#define GTK_MAJOR_VERSION[ \t]+\\(([0-9]+)\\).*" "\\1" ${_OUT_major} "${_contents}") ++ string(REGEX REPLACE ".*#define GTK_MINOR_VERSION[ \t]+\\(([0-9]+)\\).*" "\\1" ${_OUT_minor} "${_contents}") ++ string(REGEX REPLACE ".*#define GTK_MICRO_VERSION[ \t]+\\(([0-9]+)\\).*" "\\1" ${_OUT_micro} "${_contents}") ++ ++ if(NOT ${_OUT_major} MATCHES "[0-9]+") ++ message(FATAL_ERROR "Version parsing failed for GTK3_MAJOR_VERSION!") ++ endif() ++ if(NOT ${_OUT_minor} MATCHES "[0-9]+") ++ message(FATAL_ERROR "Version parsing failed for GTK3_MINOR_VERSION!") ++ endif() ++ if(NOT ${_OUT_micro} MATCHES "[0-9]+") ++ message(FATAL_ERROR "Version parsing failed for GTK3_MICRO_VERSION!") ++ endif() ++ ++ set(${_OUT_major} ${${_OUT_major}} PARENT_SCOPE) ++ set(${_OUT_minor} ${${_OUT_minor}} PARENT_SCOPE) ++ set(${_OUT_micro} ${${_OUT_micro}} PARENT_SCOPE) ++ else() ++ message(FATAL_ERROR "Include file ${_gtkversion_hdr} does not exist") ++ endif() ++endfunction() ++ ++#============================================================= ++# _GTK3_FIND_INCLUDE_DIR ++# Internal function to find the GTK include directories ++# _var = variable to set ++# _hdr = header file to look for ++#============================================================= ++function(_GTK3_FIND_INCLUDE_DIR _var _hdr) ++ ++ if(GTK3_DEBUG) ++ message(STATUS "[FindGTK3.cmake:${CMAKE_CURRENT_LIST_LINE}] " ++ "_GTK3_FIND_INCLUDE_DIR( ${_var} ${_hdr} )") ++ endif() ++ ++ set(_relatives ++ # If these ever change, things will break. ++ ${GTK3_ADDITIONAL_SUFFIXES} ++ glibmm-2.0 ++ glib-2.0 ++ atk-1.0 ++ atkmm-1.0 ++ cairo ++ cairomm-1.0 ++ gdk-pixbuf-2.0 ++ gdkmm-2.4 ++ giomm-2.4 ++ gtk-3.0 ++ gtkmm-2.4 ++ libglade-2.0 ++ libglademm-2.4 ++ pango-1.0 ++ pangomm-1.4 ++ sigc++-2.2 ++ gtk-unix-print-2.0 ++ ) ++ ++ set(_suffixes) ++ foreach(_d ${_relatives}) ++ list(APPEND _suffixes ${_d}) ++ list(APPEND _suffixes ${_d}/include) # for /usr/lib/gtk-2.0/include ++ endforeach() ++ ++ if(GTK3_DEBUG) ++ message(STATUS "[FindGTK3.cmake:${CMAKE_CURRENT_LIST_LINE}] " ++ "include suffixes = ${_suffixes}") ++ endif() ++ ++ find_path(${_var} ${_hdr} ++ PATHS ++ /usr/local/lib64 ++ /usr/local/lib ++ # fix for Ubuntu == 11.04 (Natty Narwhal) ++ /usr/lib/i386-linux-gnu/ ++ /usr/lib/x86_64-linux-gnu/ ++ # end ++ # fix for Ubuntu >= 11.10 (Oneiric Ocelot) ++ /usr/lib/${CMAKE_LIBRARY_ARCHITECTURE} ++ # end ++ /usr/lib64 ++ /usr/lib ++ /opt/gnome/include ++ /opt/gnome/lib ++ /opt/openwin/include ++ /usr/openwin/lib ++ /sw/include ++ /sw/lib ++ /opt/local/include ++ /opt/local/lib ++ $ENV{GTKMM_BASEPATH}/include ++ $ENV{GTKMM_BASEPATH}/lib ++ [HKEY_CURRENT_USER\\SOFTWARE\\gtkmm\\2.4;Path]/include ++ [HKEY_CURRENT_USER\\SOFTWARE\\gtkmm\\2.4;Path]/lib ++ [HKEY_LOCAL_MACHINE\\SOFTWARE\\gtkmm\\2.4;Path]/include ++ [HKEY_LOCAL_MACHINE\\SOFTWARE\\gtkmm\\2.4;Path]/lib ++ PATH_SUFFIXES ++ ${_suffixes} ++ ) ++ ++ if(${_var}) ++ set(GTK3_INCLUDE_DIRS ${GTK3_INCLUDE_DIRS} ${${_var}} PARENT_SCOPE) ++ if(NOT GTK3_SKIP_MARK_AS_ADVANCED) ++ mark_as_advanced(${_var}) ++ endif() ++ endif() ++ ++endfunction(_GTK3_FIND_INCLUDE_DIR) ++ ++#============================================================= ++# _GTK3_FIND_LIBRARY ++# Internal function to find libraries packaged with GTK3 ++# _var = library variable to create ++#============================================================= ++function(_GTK3_FIND_LIBRARY _var _lib _expand_vc _append_version) ++ ++ if(GTK3_DEBUG) ++ message(STATUS "[FindGTK3.cmake:${CMAKE_CURRENT_LIST_LINE}] " ++ "_GTK3_FIND_LIBRARY( ${_var} ${_lib} ${_expand_vc} ${_append_version} )") ++ endif() ++ ++ # Not GTK versions per se but the versions encoded into Windows ++ # import libraries (GtkMM 2.14.1 has a gtkmm-vc80-2_4.lib for example) ++ # Also the MSVC libraries use _ for . (this is handled below) ++ # ********* SOMEONE WITH WINDOWS NEEDS TO CHECK THIS BIT FOR V3 ********* ++ # ********* the plain 3 is needed to get Debian Sid to find the libraries ++ set(_versions 3.0 3 2.20 2.18 2.16 2.14 2.12 ++ 2.10 2.8 2.6 2.4 2.2 2.0 ++ 1.20 1.18 1.16 1.14 1.12 ++ 1.10 1.8 1.6 1.4 1.2 1.0) ++ ++ set(_library) ++ set(_library_d) ++ ++ set(_library ${_lib}) ++ ++ if(_expand_vc AND MSVC) ++ # Add vc80/vc90/vc100 midfixes ++ if(MSVC80) ++ set(_library ${_library}-vc80) ++ elseif(MSVC90) ++ set(_library ${_library}-vc90) ++ elseif(MSVC10) ++ set(_library ${_library}-vc100) ++ endif() ++ set(_library_d ${_library}-d) ++ endif() ++ ++ if(GTK3_DEBUG) ++ message(STATUS "[FindGTK3.cmake:${CMAKE_CURRENT_LIST_LINE}] " ++ "After midfix addition = ${_library} and ${_library_d}") ++ endif() ++ ++ set(_lib_list) ++ set(_libd_list) ++ if(_append_version) ++ foreach(_ver ${_versions}) ++ list(APPEND _lib_list "${_library}-${_ver}") ++ list(APPEND _libd_list "${_library_d}-${_ver}") ++ endforeach() ++ else() ++ set(_lib_list ${_library}) ++ set(_libd_list ${_library_d}) ++ endif() ++ ++ if(GTK3_DEBUG) ++ message(STATUS "[FindGTK3.cmake:${CMAKE_CURRENT_LIST_LINE}] " ++ "library list = ${_lib_list} and library debug list = ${_libd_list}") ++ endif() ++ ++ # For some silly reason the MSVC libraries use _ instead of . ++ # in the version fields ++ if(_expand_vc AND MSVC) ++ set(_no_dots_lib_list) ++ set(_no_dots_libd_list) ++ foreach(_l ${_lib_list}) ++ string(REPLACE "." "_" _no_dots_library ${_l}) ++ list(APPEND _no_dots_lib_list ${_no_dots_library}) ++ endforeach() ++ # And for debug ++ set(_no_dots_libsd_list) ++ foreach(_l ${_libd_list}) ++ string(REPLACE "." "_" _no_dots_libraryd ${_l}) ++ list(APPEND _no_dots_libd_list ${_no_dots_libraryd}) ++ endforeach() ++ ++ # Copy list back to original names ++ set(_lib_list ${_no_dots_lib_list}) ++ set(_libd_list ${_no_dots_libd_list}) ++ endif() ++ ++ if(GTK3_DEBUG) ++ message(STATUS "[FindGTK3.cmake:${CMAKE_CURRENT_LIST_LINE}] " ++ "While searching for ${_var}, our proposed library list is ${_lib_list}") ++ endif() ++ ++ find_library(${_var} ++ NAMES ${_lib_list} ++ PATHS ++ /opt/gnome/lib ++ /opt/gnome/lib64 ++ /usr/openwin/lib ++ /usr/openwin/lib64 ++ /sw/lib ++ $ENV{GTKMM_BASEPATH}/lib ++ [HKEY_CURRENT_USER\\SOFTWARE\\gtkmm\\2.4;Path]/lib ++ [HKEY_LOCAL_MACHINE\\SOFTWARE\\gtkmm\\2.4;Path]/lib ++ ) ++ ++ if(_expand_vc AND MSVC) ++ if(GTK3_DEBUG) ++ message(STATUS "[FindGTK3.cmake:${CMAKE_CURRENT_LIST_LINE}] " ++ "While searching for ${_var}_DEBUG our proposed library list is ${_libd_list}") ++ endif() ++ ++ find_library(${_var}_DEBUG ++ NAMES ${_libd_list} ++ PATHS ++ $ENV{GTKMM_BASEPATH}/lib ++ [HKEY_CURRENT_USER\\SOFTWARE\\gtkmm\\2.4;Path]/lib ++ [HKEY_LOCAL_MACHINE\\SOFTWARE\\gtkmm\\2.4;Path]/lib ++ ) ++ ++ if(${_var} AND ${_var}_DEBUG) ++ if(NOT GTK3_SKIP_MARK_AS_ADVANCED) ++ mark_as_advanced(${_var}_DEBUG) ++ endif() ++ set(GTK3_LIBRARIES ${GTK3_LIBRARIES} optimized ${${_var}} debug ${${_var}_DEBUG}) ++ set(GTK3_LIBRARIES ${GTK3_LIBRARIES} PARENT_SCOPE) ++ endif() ++ else() ++ if(NOT GTK3_SKIP_MARK_AS_ADVANCED) ++ mark_as_advanced(${_var}) ++ endif() ++ set(GTK3_LIBRARIES ${GTK3_LIBRARIES} ${${_var}}) ++ set(GTK3_LIBRARIES ${GTK3_LIBRARIES} PARENT_SCOPE) ++ # Set debug to release ++ set(${_var}_DEBUG ${${_var}}) ++ set(${_var}_DEBUG ${${_var}} PARENT_SCOPE) ++ endif() ++endfunction(_GTK3_FIND_LIBRARY) ++ ++#============================================================= ++ ++# ++# main() ++# ++ ++set(GTK3_FOUND) ++set(GTK3_INCLUDE_DIRS) ++set(GTK3_LIBRARIES) ++ ++if(NOT GTK3_FIND_COMPONENTS) ++ # Assume they only want GTK ++ set(GTK3_FIND_COMPONENTS gtk) ++endif() ++ ++# ++# If specified, enforce version number ++# ++if(GTK3_FIND_VERSION) ++ cmake_minimum_required(VERSION 2.6.2) ++ set(GTK3_FAILED_VERSION_CHECK true) ++ if(GTK3_DEBUG) ++ message(STATUS "[FindGTK3.cmake:${CMAKE_CURRENT_LIST_LINE}] " ++ "Searching for version ${GTK3_FIND_VERSION}") ++ endif() ++ _GTK3_FIND_INCLUDE_DIR(GTK3_GTK_INCLUDE_DIR gtk/gtk.h) ++ if(GTK3_GTK_INCLUDE_DIR) ++ _GTK3_GET_VERSION(GTK3_MAJOR_VERSION ++ GTK3_MINOR_VERSION ++ GTK3_PATCH_VERSION ++ ${GTK3_GTK_INCLUDE_DIR}/gtk/gtkversion.h) ++ set(GTK3_VERSION ++ ${GTK3_MAJOR_VERSION}.${GTK3_MINOR_VERSION}.${GTK3_PATCH_VERSION}) ++ if(GTK3_FIND_VERSION_EXACT) ++ if(GTK3_VERSION VERSION_EQUAL GTK3_FIND_VERSION) ++ set(GTK3_FAILED_VERSION_CHECK false) ++ endif() ++ else() ++ if(GTK3_VERSION VERSION_EQUAL GTK3_FIND_VERSION OR ++ GTK3_VERSION VERSION_GREATER GTK3_FIND_VERSION) ++ set(GTK3_FAILED_VERSION_CHECK false) ++ endif() ++ endif() ++ else() ++ # If we can't find the GTK include dir, we can't do version checking ++ if(GTK3_FIND_REQUIRED AND NOT GTK3_FIND_QUIETLY) ++ message(FATAL_ERROR "Could not find GTK3 include directory") ++ endif() ++ return() ++ endif() ++ ++ if(GTK3_FAILED_VERSION_CHECK) ++ if(GTK3_FIND_REQUIRED AND NOT GTK3_FIND_QUIETLY) ++ if(GTK3_FIND_VERSION_EXACT) ++ message(FATAL_ERROR "GTK3 version check failed. Version ${GTK3_VERSION} was found, version ${GTK3_FIND_VERSION} is needed exactly.") ++ else() ++ message(FATAL_ERROR "GTK3 version check failed. Version ${GTK3_VERSION} was found, at least version ${GTK3_FIND_VERSION} is required") ++ endif() ++ endif() ++ ++ # If the version check fails, exit out of the module here ++ return() ++ endif() ++endif() ++ ++# ++# Find all components ++# ++ ++find_package(Freetype) ++list(APPEND GTK3_INCLUDE_DIRS ${FREETYPE_INCLUDE_DIRS}) ++list(APPEND GTK3_LIBRARIES ${FREETYPE_LIBRARIES}) ++ ++foreach(_GTK3_component ${GTK3_FIND_COMPONENTS}) ++ if(_GTK3_component STREQUAL "gtk") ++ _GTK3_FIND_INCLUDE_DIR(GTK3_GLIB_INCLUDE_DIR glib.h) ++ _GTK3_FIND_INCLUDE_DIR(GTK3_GLIBCONFIG_INCLUDE_DIR glibconfig.h) ++ _GTK3_FIND_LIBRARY (GTK3_GLIB_LIBRARY glib false true) ++ ++ _GTK3_FIND_INCLUDE_DIR(GTK3_GOBJECT_INCLUDE_DIR gobject/gobject.h) ++ _GTK3_FIND_LIBRARY (GTK3_GOBJECT_LIBRARY gobject false true) ++ ++ _GTK3_FIND_INCLUDE_DIR(GTK3_GDK_PIXBUF_INCLUDE_DIR gdk-pixbuf/gdk-pixbuf.h) ++ _GTK3_FIND_LIBRARY (GTK3_GDK_PIXBUF_LIBRARY gdk_pixbuf false true) ++ ++ _GTK3_FIND_INCLUDE_DIR(GTK3_GDK_INCLUDE_DIR gdk/gdk.h) ++ _GTK3_FIND_INCLUDE_DIR(GTK3_GDKCONFIG_INCLUDE_DIR gdk/gdkconfig.h) ++ _GTK3_FIND_INCLUDE_DIR(GTK3_GTK_INCLUDE_DIR gtk/gtk.h) ++ ++ # ********* At least on Debian the gdk & gtk libraries ++ # ********* don't have the -x11 suffix. ++ if(UNIX) ++ _GTK3_FIND_LIBRARY (GTK3_GDK_LIBRARY gdk false true) ++ _GTK3_FIND_LIBRARY (GTK3_GTK_LIBRARY gtk false true) ++ else() ++ _GTK3_FIND_LIBRARY (GTK3_GDK_LIBRARY gdk-win32 false true) ++ _GTK3_FIND_LIBRARY (GTK3_GTK_LIBRARY gtk-win32 false true) ++ endif() ++ ++ _GTK3_FIND_INCLUDE_DIR(GTK3_CAIRO_INCLUDE_DIR cairo.h) ++ _GTK3_FIND_LIBRARY (GTK3_CAIRO_LIBRARY cairo false false) ++ ++ _GTK3_FIND_INCLUDE_DIR(GTK3_FONTCONFIG_INCLUDE_DIR fontconfig/fontconfig.h) ++ ++ _GTK3_FIND_INCLUDE_DIR(GTK3_PANGO_INCLUDE_DIR pango/pango.h) ++ _GTK3_FIND_LIBRARY (GTK3_PANGO_LIBRARY pango false true) ++ ++ _GTK3_FIND_INCLUDE_DIR(GTK3_ATK_INCLUDE_DIR atk/atk.h) ++ _GTK3_FIND_LIBRARY (GTK3_ATK_LIBRARY atk false true) ++ ++ ++ elseif(_GTK3_component STREQUAL "gtkmm") ++ ++ _GTK3_FIND_INCLUDE_DIR(GTK3_GLIBMM_INCLUDE_DIR glibmm.h) ++ _GTK3_FIND_INCLUDE_DIR(GTK3_GLIBMMCONFIG_INCLUDE_DIR glibmmconfig.h) ++ _GTK3_FIND_LIBRARY (GTK3_GLIBMM_LIBRARY glibmm true true) ++ ++ _GTK3_FIND_INCLUDE_DIR(GTK3_GDKMM_INCLUDE_DIR gdkmm.h) ++ _GTK3_FIND_INCLUDE_DIR(GTK3_GDKMMCONFIG_INCLUDE_DIR gdkmmconfig.h) ++ _GTK3_FIND_LIBRARY (GTK3_GDKMM_LIBRARY gdkmm true true) ++ ++ _GTK3_FIND_INCLUDE_DIR(GTK3_GTKMM_INCLUDE_DIR gtkmm.h) ++ _GTK3_FIND_INCLUDE_DIR(GTK3_GTKMMCONFIG_INCLUDE_DIR gtkmmconfig.h) ++ _GTK3_FIND_LIBRARY (GTK3_GTKMM_LIBRARY gtkmm true true) ++ ++ _GTK3_FIND_INCLUDE_DIR(GTK3_CAIROMM_INCLUDE_DIR cairomm/cairomm.h) ++ _GTK3_FIND_LIBRARY (GTK3_CAIROMM_LIBRARY cairomm true true) ++ ++ _GTK3_FIND_INCLUDE_DIR(GTK3_PANGOMM_INCLUDE_DIR pangomm.h) ++ _GTK3_FIND_INCLUDE_DIR(GTK3_PANGOMMCONFIG_INCLUDE_DIR pangommconfig.h) ++ _GTK3_FIND_LIBRARY (GTK3_PANGOMM_LIBRARY pangomm true true) ++ ++ _GTK3_FIND_INCLUDE_DIR(GTK3_SIGC++_INCLUDE_DIR sigc++/sigc++.h) ++ _GTK3_FIND_INCLUDE_DIR(GTK3_SIGC++CONFIG_INCLUDE_DIR sigc++config.h) ++ _GTK3_FIND_LIBRARY (GTK3_SIGC++_LIBRARY sigc true true) ++ ++ _GTK3_FIND_INCLUDE_DIR(GTK3_GIOMM_INCLUDE_DIR giomm.h) ++ _GTK3_FIND_INCLUDE_DIR(GTK3_GIOMMCONFIG_INCLUDE_DIR giommconfig.h) ++ _GTK3_FIND_LIBRARY (GTK3_GIOMM_LIBRARY giomm true true) ++ ++ _GTK3_FIND_INCLUDE_DIR(GTK3_ATKMM_INCLUDE_DIR atkmm.h) ++ _GTK3_FIND_LIBRARY (GTK3_ATKMM_LIBRARY atkmm true true) ++ ++ elseif(_GTK3_component STREQUAL "glade") ++ ++ _GTK3_FIND_INCLUDE_DIR(GTK3_GLADE_INCLUDE_DIR glade/glade.h) ++ _GTK3_FIND_LIBRARY (GTK3_GLADE_LIBRARY glade false true) ++ ++ elseif(_GTK3_component STREQUAL "glademm") ++ ++ _GTK3_FIND_INCLUDE_DIR(GTK3_GLADEMM_INCLUDE_DIR libglademm.h) ++ _GTK3_FIND_INCLUDE_DIR(GTK3_GLADEMMCONFIG_INCLUDE_DIR libglademmconfig.h) ++ _GTK3_FIND_LIBRARY (GTK3_GLADEMM_LIBRARY glademm true true) ++ ++ else() ++ message(FATAL_ERROR "Unknown GTK3 component ${_component}") ++ endif() ++endforeach() ++ ++# ++# Solve for the GTK3 version if we haven't already ++# ++if(NOT GTK3_FIND_VERSION AND GTK3_GTK_INCLUDE_DIR) ++ _GTK3_GET_VERSION(GTK3_MAJOR_VERSION ++ GTK3_MINOR_VERSION ++ GTK3_PATCH_VERSION ++ ${GTK3_GTK_INCLUDE_DIR}/gtk/gtkversion.h) ++ set(GTK3_VERSION ${GTK3_MAJOR_VERSION}.${GTK3_MINOR_VERSION}.${GTK3_PATCH_VERSION}) ++endif() ++ ++# ++# Try to enforce components ++# ++ ++set(_GTK3_did_we_find_everything true) # This gets set to GTK3_FOUND ++ ++include(FindPackageHandleStandardArgs) ++#include(${CMAKE_CURRENT_LIST_DIR}/FindPackageHandleStandardArgs.cmake) ++ ++foreach(_GTK3_component ${GTK3_FIND_COMPONENTS}) ++ string(TOUPPER ${_GTK3_component} _COMPONENT_UPPER) ++ ++ if(_GTK3_component STREQUAL "gtk") ++ FIND_PACKAGE_HANDLE_STANDARD_ARGS(GTK3_${_COMPONENT_UPPER} "Some or all of the gtk libraries were not found." ++ GTK3_GTK_LIBRARY ++ GTK3_GTK_INCLUDE_DIR ++ ++ GTK3_GLIB_INCLUDE_DIR ++ GTK3_GLIBCONFIG_INCLUDE_DIR ++ GTK3_GLIB_LIBRARY ++ ++ GTK3_GDK_INCLUDE_DIR ++ GTK3_GDKCONFIG_INCLUDE_DIR ++ GTK3_GDK_LIBRARY ++ ) ++ elseif(_GTK3_component STREQUAL "gtkmm") ++ FIND_PACKAGE_HANDLE_STANDARD_ARGS(GTK3_${_COMPONENT_UPPER} "Some or all of the gtkmm libraries were not found." ++ GTK3_GTKMM_LIBRARY ++ GTK3_GTKMM_INCLUDE_DIR ++ GTK3_GTKMMCONFIG_INCLUDE_DIR ++ ++ GTK3_GLIBMM_INCLUDE_DIR ++ GTK3_GLIBMMCONFIG_INCLUDE_DIR ++ GTK3_GLIBMM_LIBRARY ++ ++ GTK3_GDKMM_INCLUDE_DIR ++ GTK3_GDKMMCONFIG_INCLUDE_DIR ++ GTK3_GDKMM_LIBRARY ++ ) ++ elseif(_GTK3_component STREQUAL "glade") ++ FIND_PACKAGE_HANDLE_STANDARD_ARGS(GTK3_${_COMPONENT_UPPER} "The glade library was not found." ++ GTK3_GLADE_LIBRARY ++ GTK3_GLADE_INCLUDE_DIR ++ ) ++ elseif(_GTK3_component STREQUAL "glademm") ++ FIND_PACKAGE_HANDLE_STANDARD_ARGS(GTK3_${_COMPONENT_UPPER} "The glademm library was not found." ++ GTK3_GLADEMM_LIBRARY ++ GTK3_GLADEMM_INCLUDE_DIR ++ GTK3_GLADEMMCONFIG_INCLUDE_DIR ++ ) ++ endif() ++ ++ if(NOT GTK3_${_COMPONENT_UPPER}_FOUND) ++ set(_GTK3_did_we_find_everything false) ++ endif() ++endforeach() ++ ++if(_GTK3_did_we_find_everything AND NOT GTK3_VERSION_CHECK_FAILED) ++ set(GTK3_FOUND true) ++else() ++ # Unset our variables. ++ set(GTK3_FOUND false) ++ set(GTK3_VERSION) ++ set(GTK3_VERSION_MAJOR) ++ set(GTK3_VERSION_MINOR) ++ set(GTK3_VERSION_PATCH) ++ set(GTK3_INCLUDE_DIRS) ++ set(GTK3_LIBRARIES) ++endif() ++ ++if(GTK3_INCLUDE_DIRS) ++ list(REMOVE_DUPLICATES GTK3_INCLUDE_DIRS) ++endif() +-- +2.6.6 + diff --git a/breeze-gtk.changes b/breeze-gtk.changes index 62d92ea..6977376 100644 --- a/breeze-gtk.changes +++ b/breeze-gtk.changes @@ -1,3 +1,11 @@ +------------------------------------------------------------------- +Sat Jun 11 16:06:24 UTC 2016 - hrvoje.senjan@gmail.com + +- Update to 5.6.90~g4fcde88 + * Support GTK 3.20.x +- Add Install-GTK3-theme-version-depending-on-present-libg.patch +- Add gtk3-devel buildrequires, needed for above patch + ------------------------------------------------------------------- Sun May 15 16:50:10 UTC 2016 - hrvoje.senjan@gmail.com diff --git a/breeze-gtk.spec b/breeze-gtk.spec index bfd4f0b..c4c1c87 100644 --- a/breeze-gtk.spec +++ b/breeze-gtk.spec @@ -25,12 +25,15 @@ License: LGPL-2.1 Group: System/GUI/KDE Url: https://projects.kde.org/breeze-gtk Source: %{name}-%{version}.tar.xz +# PATCH-FIX-OPENSUSE Install-GTK3-theme-version-depending-on-present-libg.patch +Patch0: Install-GTK3-theme-version-depending-on-present-libg.patch BuildRequires: cmake >= 2.8.12 BuildRequires: extra-cmake-modules BuildRequires: fdupes BuildRequires: gcc-c++ BuildRequires: kf5-filesystem BuildRequires: pkgconfig(Qt5Core) +BuildRequires: gtk3-devel %description A GTK+ theme created to match with the new Plasma 5 Breeze theme. @@ -68,6 +71,7 @@ A GTK+ theme created to match with the new Plasma 5 Breeze theme. %prep %setup -q +%patch0 -p1 chmod a-x COPYING* README.md %build