aboutsummaryrefslogtreecommitdiff
path: root/modules
diff options
context:
space:
mode:
authorAlexander Neundorf <neundorf@kde.org>2007-08-03 01:40:00 +0000
committerAlexander Neundorf <neundorf@kde.org>2007-08-03 01:40:00 +0000
commitac081e93559fc128b739647478781a0159697f2f (patch)
tree803c765691a398d2ba2a7aff31855b3ebf53103a /modules
parent2b9a0f1b3d7a91d93a63d4cf85c2d08e71d0906d (diff)
downloadextra-cmake-modules-ac081e93559fc128b739647478781a0159697f2f.tar.gz
extra-cmake-modules-ac081e93559fc128b739647478781a0159697f2f.tar.bz2
-add FindPackageHandleStandardArgs.cmake from cmake cvs, which adds a macro for handling the QUIETLY and REQUIRED arguments
for FIND_PACKAGE() and which sets the foo_FOUND variable if all additional variables are TRUE -use this new macro in FindStrigi. -put the successful query of pkgfconfig for the strigi version in the cache, so it doesn't have to do it again the next time -if pkgconfig doesn't find strigi at all, print a warning message but don't fail Alex svn path=/trunk/KDE/kdelibs/; revision=695818
Diffstat (limited to 'modules')
-rw-r--r--modules/FindPackageHandleStandardArgs.cmake54
-rw-r--r--modules/FindStrigi.cmake68
2 files changed, 82 insertions, 40 deletions
diff --git a/modules/FindPackageHandleStandardArgs.cmake b/modules/FindPackageHandleStandardArgs.cmake
new file mode 100644
index 00000000..3f5156cf
--- /dev/null
+++ b/modules/FindPackageHandleStandardArgs.cmake
@@ -0,0 +1,54 @@
+# FIND_PACKAGE_HANDLE_STANDARD_ARGS(NAME (DEFAULT_MSG|"Custom failure message") VAR1 ... )
+# This macro is intended to be used in FindXXX.cmake modules files.
+# It handles the REQUIRED and QUIET argument to FIND_PACKAGE() and
+# it also sets the <UPPERCASED_NAME>_FOUND variable.
+# The package is found if all variables listed are TRUE.
+# Example:
+#
+# FIND_PACKAGE_HANDLE_STANDARD_ARGS(LibXml2 DEFAULT_MSG LIBXML2_LIBRARIES LIBXML2_INCLUDE_DIR)
+#
+# LibXml2 is considered to be found, if both LIBXML2_LIBRARIES and
+# LIBXML2_INCLUDE_DIR are valid. Then also LIBXML2_FOUND is set tto TRUE.
+# If it is not found and REQUIRED was used, it fails with FATAL_ERROR,
+# independent whether QUIET was used or not.
+# If it is found, the location is reported using the VAR1 argument, so
+# here a message "Found LibXml2: /usr/lib/libxml2.so" will be printed out.
+# If the second argument is DEFAULT_MSG, the message in the failure case will
+# be "Could NOT find LibXml2", if you don't like this message you can specify
+# your own custom failure message there.
+
+MACRO(FIND_PACKAGE_HANDLE_STANDARD_ARGS _NAME _FAIL_MSG _VAR1 )
+
+ IF("${_FAIL_MSG}" STREQUAL "DEFAULT_MSG")
+ SET(_FAIL_MESSAGE "Could NOT find ${_NAME}")
+ ELSE("${_FAIL_MSG}" STREQUAL "DEFAULT_MSG")
+ SET(_FAIL_MESSAGE "${_FAIL_MSG}")
+ ENDIF("${_FAIL_MSG}" STREQUAL "DEFAULT_MSG")
+
+ STRING(TOUPPER ${_NAME} _NAME_UPPER)
+
+ SET(${_NAME_UPPER}_FOUND TRUE)
+ IF(NOT ${_VAR1})
+ SET(${_NAME_UPPER}_FOUND FALSE)
+ ENDIF(NOT ${_VAR1})
+
+ FOREACH(_CURRENT_VAR ${ARGN})
+ IF(NOT ${_CURRENT_VAR})
+ SET(${_NAME_UPPER}_FOUND FALSE)
+ ENDIF(NOT ${_CURRENT_VAR})
+ ENDFOREACH(_CURRENT_VAR)
+
+ IF (${_NAME_UPPER}_FOUND)
+ IF (NOT ${_NAME}_FIND_QUIETLY)
+ MESSAGE(STATUS "Found ${_NAME}: ${${_VAR1}}")
+ ENDIF (NOT ${_NAME}_FIND_QUIETLY)
+ ELSE (${_NAME_UPPER}_FOUND)
+ IF (${_NAME}_FIND_REQUIRED)
+ MESSAGE(FATAL_ERROR "${_FAIL_MESSAGE}")
+ ELSE (${_NAME}_FIND_REQUIRED)
+ IF (NOT ${_NAME}_FIND_QUIETLY)
+ MESSAGE(STATUS "${_FAIL_MESSAGE}")
+ ENDIF (NOT ${_NAME}_FIND_QUIETLY)
+ ENDIF (${_NAME}_FIND_REQUIRED)
+ ENDIF (${_NAME_UPPER}_FOUND)
+ENDMACRO(FIND_PACKAGE_HANDLE_STANDARD_ARGS)
diff --git a/modules/FindStrigi.cmake b/modules/FindStrigi.cmake
index c6c2a883..5c24aa58 100644
--- a/modules/FindStrigi.cmake
+++ b/modules/FindStrigi.cmake
@@ -14,64 +14,52 @@ if (WIN32)
file(TO_CMAKE_PATH "$ENV{PROGRAMFILES}" _program_FILES_DIR)
endif(WIN32)
-FIND_PATH(STRIGI_INCLUDE_DIR strigi/streamanalyzer.h
+find_path(STRIGI_INCLUDE_DIR strigi/streamanalyzer.h
PATHS
$ENV{STRIGI_HOME}/include
${CMAKE_INSTALL_PREFIX}/include
${_program_FILES_DIR}/strigi/include
)
-if (NOT WIN32)
- include(UsePkgConfig)
-
- EXEC_PROGRAM(${PKGCONFIG_EXECUTABLE} ARGS --atleast-version=${STRIGI_MIN_VERSION}
- libstreamanalyzer RETURN_VALUE _return_VALUE OUTPUT_VARIABLE _pkgconfigDevNull )
-
- if(NOT _return_VALUE STREQUAL "0")
- message(STATUS "pkg-config query failed. did you set $PKG_CONFIG_PATH to the directory where strigi libstreamanalyzer.pc is installed?")
- message(FATAL_ERROR "Didn't find strigi >= ${STRIGI_MIN_VERSION}")
- else(NOT _return_VALUE STREQUAL "0")
- if(NOT Strigi_FIND_QUIETLY)
- message(STATUS "Found Strigi >= ${STRIGI_MIN_VERSION}")
- endif(NOT Strigi_FIND_QUIETLY)
- endif(NOT _return_VALUE STREQUAL "0")
-endif (NOT WIN32)
-
-FIND_LIBRARY(STRIGI_STREAMANALYZER_LIBRARY NAMES streamanalyzer
+find_library(STRIGI_STREAMANALYZER_LIBRARY NAMES streamanalyzer
PATHS
$ENV{STRIGI_HOME}/lib
${CMAKE_INSTALL_PREFIX}/lib
${_program_FILES_DIR}/strigi/lib
)
-FIND_LIBRARY(STRIGI_STREAMS_LIBRARY NAMES streams
+
+find_library(STRIGI_STREAMS_LIBRARY NAMES streams
PATHS
$ENV{STRIGI_HOME}/lib
${CMAKE_INSTALL_PREFIX}/lib
${_program_FILES_DIR}/strigi/lib
)
-IF(STRIGI_INCLUDE_DIR AND STRIGI_STREAMANALYZER_LIBRARY AND STRIGI_STREAMS_LIBRARY)
- SET(STRIGI_FOUND TRUE)
-ENDIF(STRIGI_INCLUDE_DIR AND STRIGI_STREAMANALYZER_LIBRARY AND STRIGI_STREAMS_LIBRARY)
+if (NOT WIN32 AND NOT HAVE_STRIGI_VERSION)
+ include(UsePkgConfig)
+ pkgconfig(libstreamanalyzer _dummyIncDir _dummyLinkDir _dummyLinkFlags _dummyCflags)
-IF(STRIGI_FOUND)
- SET(STRIGI_LIBRARIES ${STRIGI_STREAMANALYZER_LIBRARY} ${STRIGI_STREAMS_LIBRARY})
+ # if pkgconfig found strigi, check the version, otherwise print a warning
+ if(_dummyLinkFlags)
- IF(NOT Strigi_FIND_QUIETLY)
- MESSAGE(STATUS "Found Strigi: ${STRIGI_STREAMANALYZER_LIBRARY} ${STRIGI_STREAMS_LIBRARY} ")
- ENDIF(NOT Strigi_FIND_QUIETLY)
-ELSE(STRIGI_FOUND)
- IF(NOT Strigi_FIND_QUIETLY)
- IF(NOT STRIGI_STREAMANALYZER_LIBRARY)
- MESSAGE(STATUS "Couldn't find Strigi streamanalyzer library in $ENV{STRIGI_HOME}/lib, ${CMAKE_INSTALL_PREFIX}/lib, ${_program_FILES_DIR}/strigi/lib")
- ENDIF(NOT STRIGI_STREAMANALYZER_LIBRARY)
+ exec_program(${PKGCONFIG_EXECUTABLE} ARGS --atleast-version=${STRIGI_MIN_VERSION}
+ libstreamanalyzer RETURN_VALUE _return_VALUE OUTPUT_VARIABLE _pkgconfigDevNull )
- IF(NOT STRIGI_STREAMS_LIBRARY)
- MESSAGE(STATUS "Couldn't find Strigi streams library in $ENV{STRIGI_HOME}/lib, ${CMAKE_INSTALL_PREFIX}/lib, ${_program_FILES_DIR}/strigi/lib")
- ENDIF(NOT STRIGI_STREAMS_LIBRARY)
- ENDIF(NOT Strigi_FIND_QUIETLY)
- IF(Strigi_FIND_REQUIRED)
- MESSAGE(FATAL_ERROR "Could not find Strigi")
- ENDIF(Strigi_FIND_REQUIRED)
-ENDIF(STRIGI_FOUND)
+ if(NOT _return_VALUE STREQUAL "0")
+ message(STATUS "pkg-config query failed. did you set $PKG_CONFIG_PATH to the directory where strigi libstreamanalyzer.pc is installed?")
+ message(FATAL_ERROR "Didn't find strigi >= ${STRIGI_MIN_VERSION}")
+ else(NOT _return_VALUE STREQUAL "0")
+ set(HAVE_STRIGI_VERSION TRUE CACHE BOOL "Have strigi version returned by pkgconfig")
+ if(NOT Strigi_FIND_QUIETLY)
+ message(STATUS "Found Strigi >= ${STRIGI_MIN_VERSION}")
+ endif(NOT Strigi_FIND_QUIETLY)
+ endif(NOT _return_VALUE STREQUAL "0")
+ else(_dummyLinkFlags)
+ message(STATUS "pkgconfig didn't find strigi, couldn't check strigi version")
+ endif(_dummyLinkFlags)
+endif (NOT WIN32 AND NOT HAVE_STRIGI_VERSION)
+include(FindPackageHandleStandardArgs)
+find_package_handle_standard_args(Strigi
+ "Couldn't find Strigi streams library in $ENV{STRIGI_HOME}/lib, ${CMAKE_INSTALL_PREFIX}/lib, ${_program_FILES_DIR}/strigi/lib"
+ STRIGI_STREAMS_LIBRARY STRIGI_STREAMANALYZER_LIBRARY STRIGI_INCLUDE_DIR)