aboutsummaryrefslogtreecommitdiff
path: root/modules/FindKipi.cmake
diff options
context:
space:
mode:
Diffstat (limited to 'modules/FindKipi.cmake')
-rw-r--r--modules/FindKipi.cmake116
1 files changed, 86 insertions, 30 deletions
diff --git a/modules/FindKipi.cmake b/modules/FindKipi.cmake
index 0c6c33d7..de0d046b 100644
--- a/modules/FindKipi.cmake
+++ b/modules/FindKipi.cmake
@@ -1,41 +1,97 @@
-# - Try to find the Kipi library using cmake pkg_check_modulesi otherwise fallback to standard search
-# Once done this will define:
+# - Try to find the Kipi library
+# Once done this will define
#
# KIPI_FOUND - system has libkipi
-# KIPI_INCLUDEDIR - the libkipi include directory
+# KIPI_INCLUDE_DIR - the libkipi include directory
# KIPI_LIBRARIES - Link these to use libkipi
# KIPI_DEFINITIONS - Compiler switches required for using libkipi
+#
+
+if (KIPI_INCLUDE_DIR AND KIPI_LIBRARIES)
+
+ message(STATUS "Found Kipi library in cache: ${KIPI_LIBRARIES}")
+
+ # in cache already
+ SET(KIPI_FOUND TRUE)
+
+else (KIPI_INCLUDE_DIR AND KIPI_LIBRARIES)
+
+ message(STATUS "Check Kipi library in local sub-folder...")
+
+ # Check if library is not in local sub-folder
+
+ find_file (KIPI_LOCAL_FOUND libkipi/version.h.cmake ${CMAKE_SOURCE_DIR}/libkipi ${CMAKE_SOURCE_DIR}/libs/libkipi NO_DEFAULT_PATH)
+ if (KIPI_LOCAL_FOUND)
+
+ find_file (KIPI_LOCAL_FOUND_IN_LIBS libkipi/version.h.cmake ${CMAKE_SOURCE_DIR}/libs/libkipi NO_DEFAULT_PATH)
+ if (KIPI_LOCAL_FOUND_IN_LIBS)
+ set(KIPI_INCLUDE_DIR ${CMAKE_SOURCE_DIR}/libs/libkipi)
+ else (KIPI_LOCAL_FOUND_IN_LIBS)
+ set(KIPI_INCLUDE_DIR ${CMAKE_SOURCE_DIR}/libkipi)
+ endif (KIPI_LOCAL_FOUND_IN_LIBS)
+ set(KIPI_DEFINITIONS -I${KIPI_INCLUDE_DIR})
+ set(KIPI_LIBRARIES kipi)
+ message(STATUS "Found Kipi library in local sub-folder: ${KIPI_INCLUDE_DIR}")
+ set(KIPI_FOUND TRUE)
+ mark_as_advanced(KIPI_INCLUDE_DIR KIPI_LIBRARIES)
+
+ else(KIPI_LOCAL_FOUND)
-if (KIPI_INCLUDEDIR AND KIPI_LIBRARIES)
- # in cache already
- SET(KIPI_FOUND TRUE)
-else (KIPI_INCLUDEDIR AND KIPI_LIBRARIES)
if(NOT WIN32)
- find_package(PkgConfig)
- if(PKG_CONFIG_EXECUTABLE)
- pkg_check_modules(KIPI libkipi>=0.2.0)
- endif(PKG_CONFIG_EXECUTABLE)
+ message(STATUS "Check Kipi library using pkg-config...")
+
+ # use pkg-config to get the directories and then use these values
+ # in the FIND_PATH() and FIND_LIBRARY() calls
+ INCLUDE(UsePkgConfig)
+
+ PKGCONFIG(libkipi _KIPIIncDir _KIPILinkDir _KIPILinkFlags _KIPICflags)
+
+ if(_KIPILinkFlags)
+ # query pkg-config asking for a libkipi >= 0.2.0
+ exec_program(${PKGCONFIG_EXECUTABLE} ARGS --atleast-version=0.2.0 libkipi RETURN_VALUE _return_VALUE OUTPUT_VARIABLE _pkgconfigDevNull )
+ if(_return_VALUE STREQUAL "0")
+ message(STATUS "Found libkipi release >= 0.2.0")
+ set(KIPI_VERSION_GOOD_FOUND TRUE)
+ else(_return_VALUE STREQUAL "0")
+ message(STATUS "Found libkipi release < 0.2.0, too old")
+ set(KIPI_VERSION_GOOD_FOUND FALSE)
+ set(KIPI_FOUND FALSE)
+ endif(_return_VALUE STREQUAL "0")
+ else(_KIPILinkFlags)
+ set(KIPI_VERSION_GOOD_FOUND FALSE)
+ set(KIPI_FOUND FALSE)
+ endif(_KIPILinkFlags)
+ else(NOT WIN32)
+ set(KIPI_VERSION_GOOD_FOUND TRUE)
endif(NOT WIN32)
+ if(KIPI_VERSION_GOOD_FOUND)
+ set(KIPI_DEFINITIONS ${_KIPICflags})
+
+ find_path(KIPI_INCLUDE_DIR NAMES libkipi/version.h PATHS ${KDE4_INCLUDE_DIR} ${_KIPIIncDir})
+ find_library(KIPI_LIBRARIES NAMES kipi PATHS ${KDE4_LIB_DIR} ${_KIPILinkDir})
- if(NOT KIPI_FOUND)
- find_path(KIPI_INCLUDEDIR libkipi/version.h)
- find_library(KIPI_LIBRARIES NAMES kipi)
- if (KIPI_INCLUDEDIR AND KIPI_LIBRARIES)
+ if (KIPI_INCLUDE_DIR AND KIPI_LIBRARIES)
set(KIPI_FOUND TRUE)
- endif (KIPI_INCLUDEDIR AND KIPI_LIBRARIES)
- endif(NOT KIPI_FOUND)
+ endif (KIPI_INCLUDE_DIR AND KIPI_LIBRARIES)
+ endif(KIPI_VERSION_GOOD_FOUND)
+ if (KIPI_FOUND)
+ if (NOT Kipi_FIND_QUIETLY)
+ message(STATUS "Found libkipi: ${KIPI_LIBRARIES}")
+ endif (NOT Kipi_FIND_QUIETLY)
+ else (KIPI_FOUND)
+ if (Kipi_FIND_REQUIRED)
+ if (NOT KIPI_INCLUDE_DIR)
+ message(FATAL_ERROR "Could NOT find libkipi header files")
+ endif (NOT KIPI_INCLUDE_DIR)
+ if (NOT KIPI_LIBRARIES)
+ message(FATAL_ERROR "Could NOT find libkipi library")
+ endif (NOT KIPI_LIBRARIES)
+ endif (Kipi_FIND_REQUIRED)
+ endif (KIPI_FOUND)
- if(KIPI_FOUND)
- set(KIPI_DEFINITIONS ${KIPI_CFLAGS})
- if (NOT Kipi_FIND_QUIETLY)
- message(STATUS "Found libkipi: ${KIPI_LIBRARIES}")
- endif (NOT Kipi_FIND_QUIETLY)
- set(KIPI_INCLUDE_DIR ${KIPI_INCLUDEDIR})
- mark_as_advanced( KIPI_INCLUDE_DIR )
- else(KIPI_FOUND)
- if (Kipi_FIND_REQUIRED)
- message(FATAL_ERROR "Not found required libkipi")
- endif (Kipi_FIND_REQUIRED)
- endif (KIPI_FOUND)
-endif (KIPI_INCLUDEDIR AND KIPI_LIBRARIES)
+ MARK_AS_ADVANCED(KIPI_INCLUDE_DIR KIPI_LIBRARIES)
+
+ endif(KIPI_LOCAL_FOUND)
+
+endif (KIPI_INCLUDE_DIR AND KIPI_LIBRARIES)