FindImageMagick.cmake 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263
  1. #.rst:
  2. # FindImageMagick
  3. # ---------------
  4. #
  5. # Find the ImageMagick binary suite.
  6. #
  7. # This module will search for a set of ImageMagick tools specified as
  8. # components in the FIND_PACKAGE call. Typical components include, but
  9. # are not limited to (future versions of ImageMagick might have
  10. # additional components not listed here):
  11. #
  12. # ::
  13. #
  14. # animate
  15. # compare
  16. # composite
  17. # conjure
  18. # convert
  19. # display
  20. # identify
  21. # import
  22. # mogrify
  23. # montage
  24. # stream
  25. #
  26. #
  27. #
  28. # If no component is specified in the FIND_PACKAGE call, then it only
  29. # searches for the ImageMagick executable directory. This code defines
  30. # the following variables:
  31. #
  32. # ::
  33. #
  34. # ImageMagick_FOUND - TRUE if all components are found.
  35. # ImageMagick_EXECUTABLE_DIR - Full path to executables directory.
  36. # ImageMagick_<component>_FOUND - TRUE if <component> is found.
  37. # ImageMagick_<component>_EXECUTABLE - Full path to <component> executable.
  38. # ImageMagick_VERSION_STRING - the version of ImageMagick found
  39. # (since CMake 2.8.8)
  40. #
  41. #
  42. #
  43. # ImageMagick_VERSION_STRING will not work for old versions like 5.2.3.
  44. #
  45. # There are also components for the following ImageMagick APIs:
  46. #
  47. # ::
  48. #
  49. # Magick++
  50. # MagickWand
  51. # MagickCore
  52. #
  53. #
  54. #
  55. # For these components the following variables are set:
  56. #
  57. # ::
  58. #
  59. # ImageMagick_FOUND - TRUE if all components are found.
  60. # ImageMagick_INCLUDE_DIRS - Full paths to all include dirs.
  61. # ImageMagick_LIBRARIES - Full paths to all libraries.
  62. # ImageMagick_<component>_FOUND - TRUE if <component> is found.
  63. # ImageMagick_<component>_INCLUDE_DIRS - Full path to <component> include dirs.
  64. # ImageMagick_<component>_LIBRARIES - Full path to <component> libraries.
  65. #
  66. #
  67. #
  68. # Example Usages:
  69. #
  70. # ::
  71. #
  72. # find_package(ImageMagick)
  73. # find_package(ImageMagick COMPONENTS convert)
  74. # find_package(ImageMagick COMPONENTS convert mogrify display)
  75. # find_package(ImageMagick COMPONENTS Magick++)
  76. # find_package(ImageMagick COMPONENTS Magick++ convert)
  77. #
  78. #
  79. #
  80. # Note that the standard FIND_PACKAGE features are supported (i.e.,
  81. # QUIET, REQUIRED, etc.).
  82. #=============================================================================
  83. # Copyright 2007-2009 Kitware, Inc.
  84. # Copyright 2007-2008 Miguel A. Figueroa-Villanueva <miguelf at ieee dot org>
  85. # Copyright 2012 Rolf Eike Beer <[email protected]>
  86. #
  87. # Distributed under the OSI-approved BSD License (the "License");
  88. # see accompanying file Copyright.txt for details.
  89. #
  90. # This software is distributed WITHOUT ANY WARRANTY; without even the
  91. # implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  92. # See the License for more information.
  93. #=============================================================================
  94. # (To distribute this file outside of CMake, substitute the full
  95. # License text for the above reference.)
  96. #---------------------------------------------------------------------
  97. # Helper functions
  98. #---------------------------------------------------------------------
  99. function(FIND_IMAGEMAGICK_API component header)
  100. set(ImageMagick_${component}_FOUND FALSE PARENT_SCOPE)
  101. find_path(ImageMagick_${component}_INCLUDE_DIR
  102. NAMES ${header}
  103. PATHS
  104. ${ImageMagick_INCLUDE_DIRS}
  105. "[HKEY_LOCAL_MACHINE\\SOFTWARE\\ImageMagick\\Current;BinPath]/include"
  106. PATH_SUFFIXES
  107. ImageMagick ImageMagick-6
  108. DOC "Path to the ImageMagick include dir."
  109. )
  110. find_library(ImageMagick_${component}_LIBRARY
  111. NAMES ${ARGN}
  112. PATHS
  113. "[HKEY_LOCAL_MACHINE\\SOFTWARE\\ImageMagick\\Current;BinPath]/lib"
  114. DOC "Path to the ImageMagick Magick++ library."
  115. )
  116. if(ImageMagick_${component}_INCLUDE_DIR AND ImageMagick_${component}_LIBRARY)
  117. set(ImageMagick_${component}_FOUND TRUE PARENT_SCOPE)
  118. list(APPEND ImageMagick_INCLUDE_DIRS
  119. ${ImageMagick_${component}_INCLUDE_DIR}
  120. )
  121. list(REMOVE_DUPLICATES ImageMagick_INCLUDE_DIRS)
  122. set(ImageMagick_INCLUDE_DIRS ${ImageMagick_INCLUDE_DIRS} PARENT_SCOPE)
  123. list(APPEND ImageMagick_LIBRARIES
  124. ${ImageMagick_${component}_LIBRARY}
  125. )
  126. set(ImageMagick_LIBRARIES ${ImageMagick_LIBRARIES} PARENT_SCOPE)
  127. endif()
  128. endfunction()
  129. function(FIND_IMAGEMAGICK_EXE component)
  130. set(_IMAGEMAGICK_EXECUTABLE
  131. ${ImageMagick_EXECUTABLE_DIR}/${component}${CMAKE_EXECUTABLE_SUFFIX})
  132. if(EXISTS ${_IMAGEMAGICK_EXECUTABLE})
  133. set(ImageMagick_${component}_EXECUTABLE
  134. ${_IMAGEMAGICK_EXECUTABLE}
  135. PARENT_SCOPE
  136. )
  137. set(ImageMagick_${component}_FOUND TRUE PARENT_SCOPE)
  138. else()
  139. set(ImageMagick_${component}_FOUND FALSE PARENT_SCOPE)
  140. endif()
  141. endfunction()
  142. #---------------------------------------------------------------------
  143. # Start Actual Work
  144. #---------------------------------------------------------------------
  145. # Try to find a ImageMagick installation binary path.
  146. find_path(ImageMagick_EXECUTABLE_DIR
  147. NAMES mogrify${CMAKE_EXECUTABLE_SUFFIX}
  148. PATHS
  149. "[HKEY_LOCAL_MACHINE\\SOFTWARE\\ImageMagick\\Current;BinPath]"
  150. DOC "Path to the ImageMagick binary directory."
  151. NO_DEFAULT_PATH
  152. )
  153. find_path(ImageMagick_EXECUTABLE_DIR
  154. NAMES mogrify${CMAKE_EXECUTABLE_SUFFIX}
  155. )
  156. # Find each component. Search for all tools in same dir
  157. # <ImageMagick_EXECUTABLE_DIR>; otherwise they should be found
  158. # independently and not in a cohesive module such as this one.
  159. unset(ImageMagick_REQUIRED_VARS)
  160. unset(ImageMagick_DEFAULT_EXECUTABLES)
  161. foreach(component ${ImageMagick_FIND_COMPONENTS}
  162. # DEPRECATED: forced components for backward compatibility
  163. convert mogrify import montage composite
  164. )
  165. if(component STREQUAL "Magick++")
  166. FIND_IMAGEMAGICK_API(Magick++ Magick++.h
  167. Magick++ CORE_RL_Magick++_ Magick++-6.Q16 Magick++-Q16 Magick++-6.Q8 Magick++-Q8 Magick++-6.Q16HDRI Magick++-Q16HDRI Magick++-6.Q8HDRI Magick++-Q8HDRI
  168. )
  169. list(APPEND ImageMagick_REQUIRED_VARS ImageMagick_Magick++_LIBRARY)
  170. elseif(component STREQUAL "MagickWand")
  171. FIND_IMAGEMAGICK_API(MagickWand wand/MagickWand.h
  172. Wand MagickWand CORE_RL_wand_ MagickWand-6.Q16 MagickWand-Q16 MagickWand-6.Q8 MagickWand-Q8 MagickWand-6.Q16HDRI MagickWand-Q16HDRI MagickWand-6.Q8HDRI MagickWand-Q8HDRI
  173. )
  174. list(APPEND ImageMagick_REQUIRED_VARS ImageMagick_MagickWand_LIBRARY)
  175. elseif(component STREQUAL "MagickCore")
  176. FIND_IMAGEMAGICK_API(MagickCore magick/MagickCore.h
  177. Magick MagickCore CORE_RL_magick_ MagickCore-6.Q16 MagickCore-Q16 MagickCore-6.Q8 MagickCore-Q8 MagickCore-6.Q16HDRI MagickCore-Q16HDRI MagickCore-6.Q8HDRI MagickCore-Q8HDRI
  178. )
  179. list(APPEND ImageMagick_REQUIRED_VARS ImageMagick_MagickCore_LIBRARY)
  180. else()
  181. if(ImageMagick_EXECUTABLE_DIR)
  182. FIND_IMAGEMAGICK_EXE(${component})
  183. endif()
  184. if(ImageMagick_FIND_COMPONENTS)
  185. list(FIND ImageMagick_FIND_COMPONENTS ${component} is_requested)
  186. if(is_requested GREATER -1)
  187. list(APPEND ImageMagick_REQUIRED_VARS ImageMagick_${component}_EXECUTABLE)
  188. endif()
  189. elseif(ImageMagick_${component}_EXECUTABLE)
  190. # if no components were requested explicitly put all (default) executables
  191. # in the list
  192. list(APPEND ImageMagick_DEFAULT_EXECUTABLES ImageMagick_${component}_EXECUTABLE)
  193. endif()
  194. endif()
  195. endforeach()
  196. if(NOT ImageMagick_FIND_COMPONENTS AND NOT ImageMagick_DEFAULT_EXECUTABLES)
  197. # No components were requested, and none of the default components were
  198. # found. Just insert mogrify into the list of the default components to
  199. # find so FPHSA below has something to check
  200. list(APPEND ImageMagick_REQUIRED_VARS ImageMagick_mogrify_EXECUTABLE)
  201. elseif(ImageMagick_DEFAULT_EXECUTABLES)
  202. list(APPEND ImageMagick_REQUIRED_VARS ${ImageMagick_DEFAULT_EXECUTABLES})
  203. endif()
  204. set(ImageMagick_INCLUDE_DIRS ${ImageMagick_INCLUDE_DIRS})
  205. set(ImageMagick_LIBRARIES ${ImageMagick_LIBRARIES})
  206. if(ImageMagick_mogrify_EXECUTABLE)
  207. execute_process(COMMAND ${ImageMagick_mogrify_EXECUTABLE} -version
  208. OUTPUT_VARIABLE imagemagick_version
  209. ERROR_QUIET
  210. OUTPUT_STRIP_TRAILING_WHITESPACE)
  211. if(imagemagick_version MATCHES "^Version: ImageMagick ([-0-9\\.]+)")
  212. set(ImageMagick_VERSION_STRING "${CMAKE_MATCH_1}")
  213. endif()
  214. unset(imagemagick_version)
  215. endif()
  216. #---------------------------------------------------------------------
  217. # Standard Package Output
  218. #---------------------------------------------------------------------
  219. include(${CMAKE_CURRENT_LIST_DIR}/FindPackageHandleStandardArgs.cmake)
  220. FIND_PACKAGE_HANDLE_STANDARD_ARGS(ImageMagick
  221. REQUIRED_VARS ${ImageMagick_REQUIRED_VARS}
  222. VERSION_VAR ImageMagick_VERSION_STRING
  223. )
  224. # Maintain consistency with all other variables.
  225. set(ImageMagick_FOUND ${IMAGEMAGICK_FOUND})
  226. #---------------------------------------------------------------------
  227. # DEPRECATED: Setting variables for backward compatibility.
  228. #---------------------------------------------------------------------
  229. set(IMAGEMAGICK_BINARY_PATH ${ImageMagick_EXECUTABLE_DIR}
  230. CACHE PATH "Path to the ImageMagick binary directory.")
  231. set(IMAGEMAGICK_CONVERT_EXECUTABLE ${ImageMagick_convert_EXECUTABLE}
  232. CACHE FILEPATH "Path to ImageMagick's convert executable.")
  233. set(IMAGEMAGICK_MOGRIFY_EXECUTABLE ${ImageMagick_mogrify_EXECUTABLE}
  234. CACHE FILEPATH "Path to ImageMagick's mogrify executable.")
  235. set(IMAGEMAGICK_IMPORT_EXECUTABLE ${ImageMagick_import_EXECUTABLE}
  236. CACHE FILEPATH "Path to ImageMagick's import executable.")
  237. set(IMAGEMAGICK_MONTAGE_EXECUTABLE ${ImageMagick_montage_EXECUTABLE}
  238. CACHE FILEPATH "Path to ImageMagick's montage executable.")
  239. set(IMAGEMAGICK_COMPOSITE_EXECUTABLE ${ImageMagick_composite_EXECUTABLE}
  240. CACHE FILEPATH "Path to ImageMagick's composite executable.")
  241. mark_as_advanced(
  242. IMAGEMAGICK_BINARY_PATH
  243. IMAGEMAGICK_CONVERT_EXECUTABLE
  244. IMAGEMAGICK_MOGRIFY_EXECUTABLE
  245. IMAGEMAGICK_IMPORT_EXECUTABLE
  246. IMAGEMAGICK_MONTAGE_EXECUTABLE
  247. IMAGEMAGICK_COMPOSITE_EXECUTABLE
  248. )