diff options
Diffstat (limited to 'modules/FindKipi.cmake')
-rw-r--r-- | modules/FindKipi.cmake | 116 |
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) |