-From 66b2c16c0dec865db9c3d1720385625d22fbf021 Mon Sep 17 00:00:00 2001
-From: Andreas Sturmlechner <andreas.sturmlechner@gmail.com>
-Date: Sat, 19 Jan 2019 23:17:32 +0100
-Subject: [PATCH 1/4] Simplify CMakeLists.txt using FeatureSummary
-
----
- CMakeLists.txt | 192 +++++++++++++++++++------------------------------
- 1 file changed, 75 insertions(+), 117 deletions(-)
-
-diff --git a/CMakeLists.txt b/CMakeLists.txt
-index 9af47a75..1ffe7ff3 100644
---- a/CMakeLists.txt
-+++ b/CMakeLists.txt
-@@ -52,6 +52,8 @@ include(CMake/ListFilesResources.cmake)
- #### OPTIONS THAT CAN BE SET BY THE USER ####
- #############################################
-
-+include(FeatureSummary)
-+
- option(RAW "Use libraw library" ON)
- option(EXIV2 "Use exiv2 library" ON)
- option(GM "Use graphicsmagick library" ON)
-@@ -65,35 +67,37 @@ option(TESTING "Enable some tests" OFF)
- #### FIND REQUIRED PACKAGES ####
- ################################
-
-+find_package(Qt5 COMPONENTS Core Quick Svg Sql Xml LinguistTools REQUIRED)
-+
- if(WIN32)
-- find_package(Qt5 COMPONENTS Core Quick Svg Sql Xml LinguistTools WinExtras REQUIRED)
--elseif(NOT WIN32)
-- find_package(Qt5 COMPONENTS Core Quick Svg Sql Xml LinguistTools REQUIRED)
--endif(WIN32)
-+ find_package(Qt5WinExtras REQUIRED)
-+endif()
-
- set(CMAKE_MODULE_PATH "${CMAKE_CURRENT_SOURCE_DIR}/CMake" ${CMAKE_MODULE_PATH})
-+
-+find_package(LibArchive REQUIRED)
-+
- if(GM)
-- find_package(Magick)
--endif(GM)
-+ find_package(Magick REQUIRED)
-+endif()
- if(EXIV2)
-- find_package(Exiv2)
--endif(EXIV2)
-+ find_package(Exiv2 REQUIRED)
-+endif()
- if(RAW)
-- find_package(LibRaw)
--endif(RAW)
-+ find_package(LibRaw REQUIRED)
-+endif()
- if(FREEIMAGE)
-- find_package(FreeImage)
--endif(FREEIMAGE)
--find_package(LibArchive)
-+ find_package(FreeImage REQUIRED)
-+endif()
-
- find_package(ECM REQUIRED NO_MODULE)
- set(CMAKE_MODULE_PATH ${ECM_MODULE_PATH} "${CMAKE_MODULE_PATH}")
- if(POPPLER)
-- find_package(Poppler COMPONENTS Qt5)
--endif(POPPLER)
-+ find_package(Poppler COMPONENTS Qt5 REQUIRED)
-+endif()
- if(DEVIL)
-- find_package(DevIL)
--endif(DEVIL)
-+ find_package(DevIL REQUIRED)
-+endif()
-
- ####################################
- #### TRANSLATIONS AND RESOURCES ####
-@@ -137,14 +141,14 @@ add_definitions(-DSIMPLECRYPTKEY="${CRYPTKEY}")
- #### Add the executeable ####
- #############################
-
-+add_executable(${PROJECT_NAME} ${photoqt_SOURCES} ${photoqt_QML} ${RESOURCES})
-+target_link_libraries(${PROJECT_NAME} Qt5::Quick Qt5::Sql Qt5::Svg Qt5::Core Qt5::Xml)
-+
- # on windows we add application icons
- if(WIN32)
-- add_executable(${PROJECT_NAME} WIN32 ${photoqt_SOURCES} ${photoqt_QML} ${RESOURCES} windowsicons.rc)
-- target_link_libraries(${PROJECT_NAME} Qt5::Quick Qt5::Sql Qt5::Svg Qt5::Core Qt5::Xml Qt5::WinExtras)
--elseif(NOT WIN32)
-- add_executable(${PROJECT_NAME} ${photoqt_SOURCES} ${photoqt_QML} ${RESOURCES})
-- target_link_libraries(${PROJECT_NAME} Qt5::Quick Qt5::Sql Qt5::Svg Qt5::Core Qt5::Xml)
--endif(WIN32)
-+ add_executable(${PROJECT_NAME} WIN32 windowsicons.rc)
-+ target_link_libraries(${PROJECT_NAME} Qt5::WinExtras)
-+endif()
-
-
- ########################
-@@ -171,7 +175,7 @@ if(TESTING)
- # And inform the user
- message("** TESTING ENABLED")
-
--endif(TESTING)
-+endif()
-
-
- ##############################################
-@@ -186,112 +190,65 @@ composeDesktopFile()
- #### CUSTOM OPTIONS ####
- ########################
-
--if(NOT ${LibArchive_FOUND})
-- message(FATAL_ERROR "** Unable to locate LibArchive... is it installed?")
--elseif(${LibArchive_FOUND})
-- include_directories(${LibArchive_INCLUDE_DIRS})
-- target_link_libraries(${PROJECT_NAME} ${LibArchive_LIBRARIES})
-- message("** Found LibArchive " ${LibArchive_VERSION})
--endif(NOT ${LibArchive_FOUND})
-+include_directories(${LibArchive_INCLUDE_DIRS})
-+target_link_libraries(${PROJECT_NAME} ${LibArchive_LIBRARIES})
-
- if(POPPLER)
-- if(NOT ${Poppler_FOUND})
-- message(FATAL_ERROR "** Unable to locate Poppler... is it installed?")
-- elseif(${Poppler_FOUND})
-- include_directories(${Poppler_INCLUDE_DIRS})
-- target_link_libraries(${PROJECT_NAME} ${Poppler_LIBRARIES})
-- message("** Poppler enabled")
-- add_definitions(-DPOPPLER)
-- endif(NOT ${Poppler_FOUND})
--elseif(NOT POPPLER)
-- message("** Poppler DISABLED")
--endif(POPPLER)
-+ include_directories(${Poppler_INCLUDE_DIRS})
-+ target_link_libraries(${PROJECT_NAME} ${Poppler_LIBRARIES})
-+ add_definitions(-DPOPPLER)
-+endif()
-
- if(DEVIL)
-- if(NOT ${IL_FOUND})
-- message(FATAL_ERROR "** Unable to locate DevIL... is it installed?")
-- elseif(${IL_FOUND})
-- include_directories(${IL_INCLUDE_DIR})
-- target_link_libraries(${PROJECT_NAME} ${IL_LIBRARIES})
-- message("** DevIL enabled")
-- add_definitions(-DDEVIL)
-- endif(NOT ${IL_FOUND})
--elseif(NOT DEVIL)
-- message("** DevIL DISABLED")
--endif(DEVIL)
-+ include_directories(${IL_INCLUDE_DIR})
-+ target_link_libraries(${PROJECT_NAME} ${IL_LIBRARIES})
-+ add_definitions(-DDEVIL)
-+endif()
-
- if(FREEIMAGE)
-- if(NOT ${FREEIMAGE_FOUND})
-- message(FATAL_ERROR "** Unable to locate FreeImage... is it installed?")
-- elseif(${FREEIMAGE_FOUND})
-- include_directories(${FREEIMAGE_INCLUDE_DIRS})
-- target_link_libraries(${PROJECT_NAME} ${FREEIMAGE_LIBRARIES})
-- message("** FreeImage enabled")
-- add_definitions(-DFREEIMAGE)
-- endif(NOT ${FREEIMAGE_FOUND})
--elseif(NOT FREEIMAGE)
-- message("** FreeImage DISABLED")
--endif(FREEIMAGE)
-+ include_directories(${FREEIMAGE_INCLUDE_DIRS})
-+ target_link_libraries(${PROJECT_NAME} ${FREEIMAGE_LIBRARIES})
-+ add_definitions(-DFREEIMAGE)
-+endif()
-
- if(RAW)
-- if(NOT ${LIBRAW_FOUND})
-- message(FATAL_ERROR "** Unable to locate LibRaw... is it installed?")
-- elseif(${LIBRAW_FOUND})
-- include_directories(${LIBRAW_INCLUDE_DIR})
-- target_link_libraries(${PROJECT_NAME} "raw")
-- message("** LibRaw enabled")
-- add_definitions(-DRAW)
-- endif(NOT ${LIBRAW_FOUND})
--elseif(NOT RAW)
-- message("** LibRaw DISABLED")
--endif(RAW)
-+ include_directories(${LIBRAW_INCLUDE_DIR})
-+ target_link_libraries(${PROJECT_NAME} "raw")
-+ add_definitions(-DRAW)
-+endif()
-
- if(EXIV2)
-- if(NOT ${EXIV2_FOUND})
-- message(FATAL_ERROR "** Unable to locate Exiv2... is it installed?")
-- elseif(${EXIV2_FOUND})
-- include_directories(${EXIV2_INCLUDE_DIR})
-- target_link_libraries(${PROJECT_NAME} "exiv2")
-+ include_directories(${EXIV2_INCLUDE_DIR})
-+ target_link_libraries(${PROJECT_NAME} "exiv2")
-+ if(TESTING)
-+ target_link_libraries(${PROJECT_TEST_NAME} "exiv2")
-+ endif()
-+ if(WIN32)
-+ target_link_libraries(${PROJECT_NAME} "expat")
-+ target_link_libraries(${PROJECT_NAME} "ws2_32")
-+ target_link_libraries(${PROJECT_NAME} "wsock32")
-+ target_link_libraries(${PROJECT_NAME} "z")
-+ target_link_libraries(${PROJECT_NAME} "intl")
-+ target_link_libraries(${PROJECT_NAME} "iconv")
-+ target_link_libraries(${PROJECT_NAME} "psapi")
- if(TESTING)
-- target_link_libraries(${PROJECT_TEST_NAME} "exiv2")
-- endif(TESTING)
-- if(WIN32)
-- target_link_libraries(${PROJECT_NAME} "expat")
-- target_link_libraries(${PROJECT_NAME} "ws2_32")
-- target_link_libraries(${PROJECT_NAME} "wsock32")
-- target_link_libraries(${PROJECT_NAME} "z")
-- target_link_libraries(${PROJECT_NAME} "intl")
-- target_link_libraries(${PROJECT_NAME} "iconv")
-- target_link_libraries(${PROJECT_NAME} "psapi")
-- if(TESTING)
-- target_link_libraries(${PROJECT_TEST_NAME} "expat")
-- target_link_libraries(${PROJECT_TEST_NAME} "ws2_32")
-- target_link_libraries(${PROJECT_TEST_NAME} "wsock32")
-- target_link_libraries(${PROJECT_TEST_NAME} "z")
-- target_link_libraries(${PROJECT_TEST_NAME} "intl")
-- target_link_libraries(${PROJECT_TEST_NAME} "iconv")
-- target_link_libraries(${PROJECT_TEST_NAME} "psapi")
-- endif(TESTING)
-- endif(WIN32)
-- add_definitions(-DEXIV2)
-- message("** Exiv2 enabled")
-- endif(NOT ${EXIV2_FOUND})
--elseif(NOT EXIV2)
-- message("** Exiv2 DISABLED")
--endif(EXIV2)
-+ target_link_libraries(${PROJECT_TEST_NAME} "expat")
-+ target_link_libraries(${PROJECT_TEST_NAME} "ws2_32")
-+ target_link_libraries(${PROJECT_TEST_NAME} "wsock32")
-+ target_link_libraries(${PROJECT_TEST_NAME} "z")
-+ target_link_libraries(${PROJECT_TEST_NAME} "intl")
-+ target_link_libraries(${PROJECT_TEST_NAME} "iconv")
-+ target_link_libraries(${PROJECT_TEST_NAME} "psapi")
-+ endif()
-+ endif()
-+ add_definitions(-DEXIV2)
-+endif()
-
- if(GM)
-- if(NOT ${MAGICK++_FOUND})
-- message(FATAL_ERROR "** Unable to locate GraphicsMagick... is it installed?")
-- elseif(${MAGICK++_FOUND})
-- include_directories(${MAGICK++_INCLUDE_DIR})
-- target_link_libraries(${PROJECT_NAME} "GraphicsMagick++")
-- add_definitions(-DGM)
-- message("** Graphicsmagick enabled")
-- endif(NOT ${MAGICK++_FOUND})
--elseif(NOT GM)
-- message("** Graphicsmagick DISABLED")
--endif(GM)
-+ include_directories(${MAGICK++_INCLUDE_DIR})
-+ target_link_libraries(${PROJECT_NAME} "GraphicsMagick++")
-+ add_definitions(-DGM)
-+endif()
-
-
- #######################
-@@ -339,6 +296,7 @@ if(UNIX)
- )
- endif(UNIX)
-
-+feature_summary(WHAT ALL INCLUDE_QUIET_PACKAGES FATAL_ON_MISSING_REQUIRED_PACKAGES)
-
-
- ##########################
---
-2.20.1
-
-
-From b58268b06eb62de70da3ac751870114b07cd79e3 Mon Sep 17 00:00:00 2001
-From: Andreas Sturmlechner <andreas.sturmlechner@gmail.com>
-Date: Sun, 20 Jan 2019 17:49:09 +0100
-Subject: [PATCH 2/4] Switch to FindLibExiv2 from ECM 5.54.0
-
-Fixes detection of exiv2.
----
- CMake/FindLibExiv2.cmake | 115 +++++++++++++++++++++++++++++++++++++++
- CMakeLists.txt | 7 +--
- create mode 100644 CMake/FindLibExiv2.cmake
-
-diff --git a/CMake/FindLibExiv2.cmake b/CMake/FindLibExiv2.cmake
-new file mode 100644
-index 00000000..935cee2c
---- /dev/null
-+++ b/CMake/FindLibExiv2.cmake
-@@ -0,0 +1,115 @@
-+#.rst:
-+# FindLibExiv2
-+# ------------
-+#
-+# Try to find the Exiv2 library.
-+#
-+# This will define the following variables:
-+#
-+# ``LibExiv2_FOUND``
-+# System has LibExiv2.
-+#
-+# ``LibExiv2_VERSION``
-+# The version of LibExiv2.
-+#
-+# ``LibExiv2_INCLUDE_DIRS``
-+# This should be passed to target_include_directories() if
-+# the target is not used for linking.
-+#
-+# ``LibExiv2_LIBRARIES``
-+# The LibExiv2 library.
-+# This can be passed to target_link_libraries() instead of
-+# the ``LibExiv2::LibExiv2`` target
-+#
-+# If ``LibExiv2_FOUND`` is TRUE, the following imported target
-+# will be available:
-+#
-+# ``LibExiv2::LibExiv2``
-+# The Exiv2 library
-+#
-+# Since 5.53.0.
-+#
-+#=============================================================================
-+# Copyright (c) 2018, Christophe Giboudeaux, <christophe@krop.fr>
-+# Copyright (c) 2010, Alexander Neundorf, <neundorf@kde.org>
-+# Copyright (c) 2008, Gilles Caulier, <caulier.gilles@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.
-+#=============================================================================
-+
-+find_package(PkgConfig QUIET)
-+pkg_check_modules(PC_EXIV2 QUIET exiv2)
-+
-+find_path(LibExiv2_INCLUDE_DIRS NAMES exiv2/exif.hpp
-+ HINTS ${PC_EXIV2_INCLUDEDIR}
-+)
-+
-+find_library(LibExiv2_LIBRARIES NAMES exiv2 libexiv2
-+ HINTS ${PC_EXIV2_LIBRARY_DIRS}
-+)
-+
-+set(LibExiv2_VERSION ${PC_EXIV2_VERSION})
-+
-+if(NOT LibExiv2_VERSION AND DEFINED LibExiv2_INCLUDE_DIRS)
-+ # With exiv >= 0.27, the version #defines are in exv_conf.h instead of version.hpp
-+ foreach(_exiv2_version_file "version.hpp" "exv_conf.h")
-+ if(EXISTS "${LibExiv2_INCLUDE_DIRS}/exiv2/${_exiv2_version_file}")
-+ file(READ "${LibExiv2_INCLUDE_DIRS}/exiv2/${_exiv2_version_file}" _exiv_version_file_content)
-+ string(REGEX MATCH "#define EXIV2_MAJOR_VERSION[ ]+\\([0-9]+\\)" EXIV2_MAJOR_VERSION_MATCH ${_exiv_version_file_content})
-+ string(REGEX MATCH "#define EXIV2_MINOR_VERSION[ ]+\\([0-9]+\\)" EXIV2_MINOR_VERSION_MATCH ${_exiv_version_file_content})
-+ string(REGEX MATCH "#define EXIV2_PATCH_VERSION[ ]+\\([0-9]+\\)" EXIV2_PATCH_VERSION_MATCH ${_exiv_version_file_content})
-+ if(EXIV2_MAJOR_VERSION_MATCH)
-+ string(REGEX REPLACE ".*_MAJOR_VERSION[ ]+\\((.*)\\)" "\\1" EXIV2_MAJOR_VERSION ${EXIV2_MAJOR_VERSION_MATCH})
-+ string(REGEX REPLACE ".*_MINOR_VERSION[ ]+\\((.*)\\)" "\\1" EXIV2_MINOR_VERSION ${EXIV2_MINOR_VERSION_MATCH})
-+ string(REGEX REPLACE ".*_PATCH_VERSION[ ]+\\((.*)\\)" "\\1" EXIV2_PATCH_VERSION ${EXIV2_PATCH_VERSION_MATCH})
-+ endif()
-+ endif()
-+ endforeach()
-+
-+ set(LibExiv2_VERSION "${EXIV2_MAJOR_VERSION}.${EXIV2_MINOR_VERSION}.${EXIV2_PATCH_VERSION}")
-+endif()
-+
-+include(FindPackageHandleStandardArgs)
-+find_package_handle_standard_args(LibExiv2
-+ FOUND_VAR LibExiv2_FOUND
-+ REQUIRED_VARS LibExiv2_LIBRARIES LibExiv2_INCLUDE_DIRS
-+ VERSION_VAR LibExiv2_VERSION
-+)
-+
-+mark_as_advanced(LibExiv2_INCLUDE_DIRS LibExiv2_LIBRARIES)
-+
-+if(LibExiv2_FOUND AND NOT TARGET LibExiv2::LibExiv2)
-+ add_library(LibExiv2::LibExiv2 UNKNOWN IMPORTED)
-+ set_target_properties(LibExiv2::LibExiv2 PROPERTIES
-+ IMPORTED_LOCATION "${LibExiv2_LIBRARIES}"
-+ INTERFACE_INCLUDE_DIRECTORIES "${LibExiv2_INCLUDE_DIRS}"
-+ )
-+endif()
-+
-+include(FeatureSummary)
-+set_package_properties(LibExiv2 PROPERTIES
-+ URL "http://www.exiv2.org"
-+ DESCRIPTION "Image metadata support"
-+)
-diff --git a/CMakeLists.txt b/CMakeLists.txt
-index 1ffe7ff3..b96b21db 100644
---- a/CMakeLists.txt
-+++ b/CMakeLists.txt
-@@ -81,7 +81,7 @@ if(GM)
- find_package(Magick REQUIRED)
- endif()
- if(EXIV2)
-- find_package(Exiv2 REQUIRED)
-+ find_package(LibExiv2 REQUIRED)
- endif()
- if(RAW)
- find_package(LibRaw REQUIRED)
-@@ -218,10 +218,9 @@ if(RAW)
- endif()
-
- if(EXIV2)
-- include_directories(${EXIV2_INCLUDE_DIR})
-- target_link_libraries(${PROJECT_NAME} "exiv2")
-+ target_link_libraries(${PROJECT_NAME} LibExiv2::LibExiv2)
- if(TESTING)
-- target_link_libraries(${PROJECT_TEST_NAME} "exiv2")
-+ target_link_libraries(${PROJECT_TEST_NAME} LibExiv2::LibExiv2)
- endif()
- if(WIN32)
- target_link_libraries(${PROJECT_NAME} "expat")
---
-2.20.1
-
-
-From f2a675ea5496febae1daee229ad132086dec24bc Mon Sep 17 00:00:00 2001
+From c6fd41478e818f3a651d40f96cab3d790e1c09a4 Mon Sep 17 00:00:00 2001
From: Andreas Sturmlechner <andreas.sturmlechner@gmail.com>
Date: Sun, 20 Jan 2019 18:25:45 +0100
-Subject: [PATCH 3/4] Fix build with exiv2-0.27
+Subject: [PATCH] Fix build with exiv2-0.27
+Fixes https://gitlab.com/luspi/photoqt/issues/64
---
cplusplus/scripts/getanddostuff/manipulation.h | 3 +--
cplusplus/scripts/getmetadata.cpp | 4 ++--
class ManagePeopleTags : public QObject {
--
-2.20.1
+2.18.1