CMakeLists.txt 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670
  1. ###########################################################################
  2. #
  3. # Library: CTK
  4. #
  5. # Copyright (c) Kitware Inc.
  6. #
  7. # Licensed under the Apache License, Version 2.0 (the "License");
  8. # you may not use this file except in compliance with the License.
  9. # You may obtain a copy of the License at
  10. #
  11. # http://www.commontk.org/LICENSE
  12. #
  13. # Unless required by applicable law or agreed to in writing, software
  14. # distributed under the License is distributed on an "AS IS" BASIS,
  15. # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  16. # See the License for the specific language governing permissions and
  17. # limitations under the License.
  18. #
  19. ###########################################################################
  20. CMAKE_MINIMUM_REQUIRED(VERSION 2.8.2)
  21. #-----------------------------------------------------------------------------
  22. # See http://cmake.org/cmake/help/cmake-2-8-docs.html#section_Policies for details
  23. #
  24. SET(project_policies
  25. CMP0001 # NEW: CMAKE_BACKWARDS_COMPATIBILITY should no longer be used.
  26. CMP0002 # NEW: Logical target names must be globally unique.
  27. CMP0003 # NEW: Libraries linked via full path no longer produce linker search paths.
  28. CMP0004 # NEW: Libraries linked may NOT have leading or trailing whitespace.
  29. CMP0005 # NEW: Preprocessor definition values are now escaped automatically.
  30. CMP0006 # NEW: Installing MACOSX_BUNDLE targets requires a BUNDLE DESTINATION.
  31. CMP0007 # NEW: List command no longer ignores empty elements.
  32. CMP0008 # NEW: Libraries linked by full-path must have a valid library file name.
  33. CMP0009 # NEW: FILE GLOB_RECURSE calls should not follow symlinks by default.
  34. CMP0010 # NEW: Bad variable reference syntax is an error.
  35. CMP0011 # NEW: Included scripts do automatic cmake_policy PUSH and POP.
  36. CMP0012 # NEW: if() recognizes numbers and boolean constants.
  37. CMP0013 # NEW: Duplicate binary directories are not allowed.
  38. CMP0014 # NEW: Input directories must have CMakeLists.txt
  39. )
  40. FOREACH(policy ${project_policies})
  41. IF(POLICY ${policy})
  42. CMAKE_POLICY(SET ${policy} NEW)
  43. ENDIF()
  44. ENDFOREACH()
  45. #-----------------------------------------------------------------------------
  46. PROJECT(CTK)
  47. #-----------------------------------------------------------------------------
  48. #-----------------------------------------------------------------------------
  49. # Default to shared library
  50. SET(CTK_LIBRARY_MODE "SHARED")
  51. SET(CTK_BUILD_SHARED_LIBS TRUE)
  52. #-----------------------------------------------------------------------------
  53. # Superbuild Option - Enabled by default
  54. #
  55. OPTION(CTK_SUPERBUILD "Build CTK and the projects it depends on via SuperBuild.cmake." ON)
  56. MARK_AS_ADVANCED(CTK_SUPERBUILD)
  57. #-----------------------------------------------------------------------------
  58. # Output directories.
  59. #
  60. FOREACH(type LIBRARY RUNTIME ARCHIVE)
  61. # Make sure the directory exists
  62. IF(DEFINED CTK_CMAKE_${type}_OUTPUT_DIRECTORY
  63. AND NOT EXISTS ${CTK_CMAKE_${type}_OUTPUT_DIRECTORY})
  64. MESSAGE(FATAL_ERROR "CTK_CMAKE_${type}_OUTPUT_DIRECTORY is set to a non-existing directory [${CTK_CMAKE_${type}_OUTPUT_DIRECTORY}]")
  65. ENDIF()
  66. IF(CTK_SUPERBUILD)
  67. SET(output_dir ${CTK_BINARY_DIR}/bin)
  68. IF(NOT DEFINED CTK_CMAKE_${type}_OUTPUT_DIRECTORY)
  69. SET(CTK_CMAKE_${type}_OUTPUT_DIRECTORY ${CTK_BINARY_DIR}/CTK-build/bin)
  70. ENDIF()
  71. ELSE()
  72. IF(NOT DEFINED CTK_CMAKE_${type}_OUTPUT_DIRECTORY)
  73. SET(output_dir ${CTK_BINARY_DIR}/bin)
  74. ELSE()
  75. SET(output_dir ${CTK_CMAKE_${type}_OUTPUT_DIRECTORY})
  76. ENDIF()
  77. ENDIF()
  78. SET(CMAKE_${type}_OUTPUT_DIRECTORY ${output_dir} CACHE INTERNAL "Single output directory for building all libraries.")
  79. ENDFOREACH()
  80. #-----------------------------------------------------------------------------
  81. # CTK version number. An even minor number corresponds to releases.
  82. #
  83. SET(CTK_MAJOR_VERSION 0)
  84. SET(CTK_MINOR_VERSION 1)
  85. SET(CTK_BUILD_VERSION 0)
  86. SET(CTK_VERSION
  87. "${CTK_MAJOR_VERSION}.${CTK_MINOR_VERSION}.${CTK_BUILD_VERSION}")
  88. # Append the library version information to the library target
  89. # properties. A parent project may set its own properties and/or may
  90. # block this.
  91. IF(NOT CTK_NO_LIBRARY_VERSION)
  92. SET(CTK_LIBRARY_PROPERTIES ${CTK_LIBRARY_PROPERTIES}
  93. VERSION "${CTK_VERSION}"
  94. SOVERSION "${CTK_MAJOR_VERSION}.${CTK_MINOR_VERSION}"
  95. )
  96. ENDIF()
  97. #-----------------------------------------------------------------------------
  98. # Install directories, used for install rules.
  99. #
  100. IF(NOT CTK_INSTALL_BIN_DIR)
  101. SET(CTK_INSTALL_BIN_DIR "bin")
  102. ENDIF()
  103. IF(NOT CTK_INSTALL_LIB_DIR)
  104. SET(CTK_INSTALL_LIB_DIR "lib/ctk-${CTK_MAJOR_VERSION}.${CTK_MINOR_VERSION}")
  105. ENDIF()
  106. IF(NOT CTK_INSTALL_INCLUDE_DIR)
  107. SET(CTK_INSTALL_INCLUDE_DIR "include/ctk-${CTK_MAJOR_VERSION}.${CTK_MINOR_VERSION}")
  108. ENDIF()
  109. IF(NOT CTK_INSTALL_DOC_DIR)
  110. SET(CTK_INSTALL_DOC_DIR "doc")
  111. ENDIF()
  112. #-----------------------------------------------------------------------------
  113. # Update CMake module path
  114. # Note: FindXXX.cmake script specific to utility should be copied into Utilities/CMake
  115. #
  116. SET(CMAKE_MODULE_PATH
  117. "${CMAKE_CURRENT_SOURCE_DIR}/Utilities/CMake"
  118. "${CMAKE_CURRENT_SOURCE_DIR}/CMake"
  119. ${CMAKE_MODULE_PATH})
  120. #-----------------------------------------------------------------------------
  121. # Clear CTK_BASE_INCLUDE_DIRS, CTK_BASE_LIBRARIES and CTK_WRAPPED_LIBRARIES_PYTHONQT
  122. #
  123. SET(CTK_BASE_LIBRARIES CACHE INTERNAL "CTK base libraries" FORCE)
  124. SET(CTK_BASE_INCLUDE_DIRS CACHE INTERNAL "CTK includes" FORCE)
  125. SET(CTK_WRAPPED_LIBRARIES_PYTHONQT CACHE INTERNAL "CTK libraries wrapped using PythonQt" FORCE)
  126. # Variable use in CTKConfig.cmake.in
  127. SET(CTK_LIBRARIES CACHE INTERNAL "CTK libraries" FORCE)
  128. SET(CTK_PLUGIN_LIBRARIES CACHE INTERNAL "CTK plugins" FORCE)
  129. # Used by CTKGenerateCTKConfig.cmake and also used to reference script from other scripts
  130. SET(CTK_CMAKE_DIR ${CTK_SOURCE_DIR}/CMake)
  131. SET(CTK_CMAKE_UTILITIES_DIR ${CTK_SOURCE_DIR}/Utilities/CMake)
  132. #-----------------------------------------------------------------------------
  133. # CMake Function(s) and Macro(s)
  134. #
  135. INCLUDE(CMake/ctkMacroParseArguments.cmake)
  136. INCLUDE(CMake/ctkMacroSetPaths.cmake)
  137. INCLUDE(CMake/ctkMacroListFilter.cmake)
  138. INCLUDE(CMake/ctkMacroBuildLib.cmake)
  139. INCLUDE(CMake/ctkMacroBuildPlugin.cmake)
  140. INCLUDE(CMake/ctkMacroBuildApp.cmake)
  141. INCLUDE(CMake/ctkMacroBuildQtDesignerPlugin.cmake)
  142. INCLUDE(CMake/ctkMacroCompilePythonScript.cmake)
  143. INCLUDE(CMake/ctkMacroWrapPythonQt.cmake)
  144. INCLUDE(CMake/ctkMacroSetupQt.cmake)
  145. INCLUDE(CMake/ctkMacroTargetLibraries.cmake) # Import multiple macros
  146. INCLUDE(CMake/ctkFunctionExtractOptionNameAndValue.cmake)
  147. INCLUDE(CMake/ctkMacroValidateBuildOptions.cmake)
  148. INCLUDE(CMake/ctkMacroAddCtkLibraryOptions.cmake)
  149. INCLUDE(CMake/ctkFunctionGenerateDGraphInput.cmake)
  150. INCLUDE(CMake/ctkFunctionGenerateProjectXml.cmake)
  151. INCLUDE(CMake/ctkFunctionGeneratePluginManifest.cmake)
  152. INCLUDE(CMake/ctkMacroGeneratePluginResourceFile.cmake)
  153. INCLUDE(CMake/ctkFunctionCheckCompilerFlags.cmake)
  154. INCLUDE(CMake/ctkFunctionGetIncludeDirs.cmake)
  155. INCLUDE(CMake/ctkFunctionGetGccVersion.cmake)
  156. #-----------------------------------------------------------------------------
  157. # Testing
  158. #
  159. OPTION(BUILD_TESTING "Test the project" ON)
  160. IF(BUILD_TESTING)
  161. ENABLE_TESTING()
  162. INCLUDE(CTest)
  163. SET(CPP_TEST_PATH ${CMAKE_RUNTIME_OUTPUT_DIRECTORY})
  164. MARK_AS_ADVANCED(TCL_TCLSH DART_ROOT)
  165. # Setup file for setting custom ctest vars
  166. CONFIGURE_FILE(
  167. CMake/CTestCustom.cmake.in
  168. ${CMAKE_CURRENT_BINARY_DIR}/CTestCustom.cmake
  169. @ONLY
  170. )
  171. # Configuration for the CMake-generated test driver
  172. SET(CMAKE_TESTDRIVER_EXTRA_INCLUDES "#include <stdexcept>")
  173. SET(CMAKE_TESTDRIVER_BEFORE_TESTMAIN "
  174. try
  175. {")
  176. SET(CMAKE_TESTDRIVER_AFTER_TESTMAIN " }
  177. catch( std::exception & excp )
  178. {
  179. fprintf(stderr,\"%s\\n\",excp.what());
  180. return EXIT_FAILURE;
  181. }
  182. catch( ... )
  183. {
  184. printf(\"Exception caught in the test driver\\n\");
  185. return EXIT_FAILURE;
  186. }
  187. ")
  188. ENDIF()
  189. #-----------------------------------------------------------------------------
  190. # Coverage
  191. #
  192. OPTION(WITH_COVERAGE "Enable/Disable coverage" OFF)
  193. #-----------------------------------------------------------------------------
  194. # Documentation
  195. #
  196. OPTION(DOCUMENTATION_TARGET_IN_ALL "Include the custom target for building documentation in 'all'" OFF)
  197. MARK_AS_ADVANCED(DOCUMENTATION_TARGET_IN_ALL)
  198. SET(DOCUMENTATION_ARCHIVES_OUTPUT_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
  199. CACHE PATH "Where documentation archives should be stored")
  200. MARK_AS_ADVANCED(DOCUMENTATION_ARCHIVES_OUTPUT_DIRECTORY)
  201. #-----------------------------------------------------------------------------
  202. # Additional CXX/C Flags
  203. #
  204. SET(ADDITIONAL_C_FLAGS "" CACHE STRING "Additional C Flags")
  205. MARK_AS_ADVANCED(ADDITIONAL_C_FLAGS)
  206. SET(ADDITIONAL_CXX_FLAGS "" CACHE STRING "Additional CXX Flags")
  207. MARK_AS_ADVANCED(ADDITIONAL_CXX_FLAGS)
  208. #-----------------------------------------------------------------------------
  209. # Set symbol visibility Flags
  210. #
  211. # MinGW does not export all symbols automatically, so no need to set flags
  212. IF(CMAKE_COMPILER_IS_GNUCXX AND NOT MINGW)
  213. SET(VISIBILITY_CXX_FLAGS "-fvisibility=hidden -fvisibility-inlines-hidden")
  214. ENDIF()
  215. #-----------------------------------------------------------------------------
  216. # Set coverage Flags
  217. #
  218. IF(WITH_COVERAGE)
  219. IF("${CMAKE_CXX_COMPILER_ID}" STREQUAL "GNU")
  220. SET(coverage_flags "-g -fprofile-arcs -ftest-coverage -O0 -DNDEBUG")
  221. SET(COVERAGE_CXX_FLAGS ${coverage_flags})
  222. SET(COVERAGE_C_FLAGS ${coverage_flags})
  223. ENDIF()
  224. ENDIF()
  225. #-----------------------------------------------------------------------------
  226. # CTK C/CXX Flags
  227. #
  228. SET(CTK_C_FLAGS "${CMAKE_C_FLAGS_INIT} ${COVERAGE_C_FLAGS} ${ADDITIONAL_C_FLAGS}")
  229. SET(CTK_CXX_FLAGS "${CMAKE_CXX_FLAGS_INIT} ${VISIBILITY_CXX_FLAGS} ${COVERAGE_CXX_FLAGS} ${ADDITIONAL_CXX_FLAGS}")
  230. IF(CMAKE_COMPILER_IS_GNUCXX)
  231. SET(cflags "-Wall -Wextra -Wpointer-arith -Winvalid-pch -Wcast-align -Wwrite-strings -D_FORTIFY_SOURCE=2")
  232. ctkFunctionCheckCompilerFlags("-fdiagnostics-show-option" cflags)
  233. ctkFunctionGetGccVersion(${CMAKE_CXX_COMPILER} GCC_VERSION)
  234. # With older version of gcc supporting the flag -fstack-protector-all, an extra dependency to libssp.so
  235. # is introduced. If gcc is smaller than 4.4.0 and the build type is Release let's not include the flag.
  236. # Doing so should allow to build package made for distribution using older linux distro.
  237. IF(${GCC_VERSION} VERSION_GREATER "4.4.0" OR (CMAKE_BUILD_TYPE STREQUAL "Debug" AND ${GCC_VERSION} VERSION_LESS "4.4.0"))
  238. ctkFunctionCheckCompilerFlags("-fstack-protector-all" cflags)
  239. ENDIF()
  240. IF(MINGW)
  241. # suppress warnings about auto imported symbols
  242. SET(CTK_CXX_FLAGS "-Wl,--enable-auto-import ${CTK_CXX_FLAGS}")
  243. ENDIF()
  244. SET(CTK_C_FLAGS "${cflags} ${CTK_C_FLAGS}")
  245. SET(CTK_CXX_FLAGS "${cflags} -Wl,--no-undefined -Woverloaded-virtual -Wold-style-cast -Wstrict-null-sentinel -Wsign-promo ${CTK_CXX_FLAGS}")
  246. ENDIF()
  247. IF(MSVC)
  248. SET(msvc_suppressed_warnings
  249. "/wd4290" # C++ exception specification ignored except to indicate a function is not __declspec(nothrow)
  250. )
  251. SET(CTK_CXX_FLAGS "${CTK_CXX_FLAGS} ${msvc_suppressed_warnings}")
  252. ENDIF()
  253. #-----------------------------------------------------------------------------
  254. # QT
  255. #
  256. ctkMacroSetupQt()
  257. # Update CTK_BASE_LIBRARIES with QT libraries
  258. IF(QT4_FOUND)
  259. SET(CTK_BASE_LIBRARIES ${CTK_BASE_LIBRARIES} ${QT_LIBRARIES} CACHE INTERNAL "CTK base libraries" FORCE)
  260. ENDIF()
  261. #-----------------------------------------------------------------------------
  262. # CTK Libraries - Use ON or OFF to indicate if the library should be built by default
  263. #
  264. SET(CTK_LIBS
  265. Core:ON
  266. PluginFramework:ON
  267. Widgets:OFF
  268. DICOM/Core:OFF
  269. DICOM/Widgets:OFF
  270. #Messaging/Core:OFF # MessagingCore library need some love :) - Let's disable it for now :(
  271. Scripting/Python/Core:OFF
  272. Scripting/Python/Widgets:OFF
  273. Visualization/VTK/Core:OFF
  274. Visualization/VTK/Widgets:OFF
  275. #Visualization/XIP:OFF # XIP library need some love :) - Let's disable it for now :(
  276. )
  277. #-----------------------------------------------------------------------------
  278. # CTK Plugins - Use ON or OFF to indicate if the plugin should be built by default
  279. #
  280. SET(CTK_PLUGINS
  281. org.commontk.eventbus:OFF
  282. #org.commontk.cli:OFF # MessagingCore library need some love :) - Let's disable it for now :(
  283. org.commontk.configadmin:OFF
  284. org.commontk.dah.app:OFF
  285. org.commontk.dah.core:OFF
  286. org.commontk.dah.exampleapp:OFF
  287. org.commontk.dah.examplehost:OFF
  288. org.commontk.dah.host:OFF
  289. org.commontk.eventadmin:OFF
  290. org.commontk.log:OFF
  291. org.commontk.log4qt:OFF
  292. org.commontk.metatype:OFF
  293. org.commontk.plugingenerator.core:OFF
  294. org.commontk.plugingenerator.ui:OFF
  295. org.commontk.qtmobility.service:OFF
  296. )
  297. #-----------------------------------------------------------------------------
  298. # CTK Applications - Use ON or OFF to indicate if the application should be built by default
  299. #
  300. SET(CTK_APPLICATIONS
  301. ctkCLIPluginExplorer:OFF
  302. ctkDICOM:OFF
  303. ctkDICOMIndexer:OFF
  304. ctkDICOMDemoSCU:OFF
  305. ctkDICOMQuery:OFF
  306. ctkDICOMRetrieve:OFF
  307. ctkDICOMQueryRetrieve:OFF
  308. ctkExampleHost:OFF
  309. ctkExampleHostedApp:OFF
  310. ctkPluginBrowser:OFF
  311. ctkPluginGenerator:OFF
  312. ctkDICOMObjectViewer:OFF
  313. ctkSimplePythonShell:OFF
  314. )
  315. #-----------------------------------------------------------------------------
  316. # To make options show up in both CTK-SuperBuild and CTK regular build, let's add them
  317. # before the SuperBuild script is included
  318. #
  319. # Let's mark as advanced some default properties
  320. MARK_AS_ADVANCED(CMAKE_INSTALL_PREFIX)
  321. MARK_AS_ADVANCED(DART_TESTING_TIMEOUT)
  322. # KWStyle
  323. OPTION(CTK_USE_KWSTYLE "Enable sourcecode-based style tests." OFF)
  324. #MARK_AS_ADVANCED(CTK_USE_KWSTYLE)
  325. #---------------------------------------------------------------------------
  326. # Will contain a list of sub-directory without option ON or OFF
  327. #
  328. SET(CTK_LIBS_SUBDIRS )
  329. SET(CTK_PLUGINS_SUBDIRS )
  330. SET(CTK_APPLICATIONS_SUBDIRS )
  331. #-----------------------------------------------------------------------------
  332. # Build options associated with CTK libraries
  333. #
  334. # The following FOREACH loops are used to:
  335. # 1) Add build options associated with either libraries, plugins and applications
  336. # 2) Update either CTK_LIBS_SUBDIRS, CTK_PLUGINS_SUBDIRS or CTK_APPS_SUBDIRS variables
  337. #
  338. # For CTK libraries, if the file Libs/<DIR>/<LIBNAME>/ctk_library_options.cmake exists,
  339. # in addition to 'CTK_LIB_<DIR>/<LIBNAME>' option, the following ones
  340. # will also be available in CMake configure menu:
  341. # CTK_LIB_<DIR>/<LIBNAME>_OPT1 (set to OFF)
  342. # CTK_LIB_<DIR>/<LIBNAME>_OPT2 (set to ON)
  343. #
  344. # The file Libs/<DIR>/<LIBNAME>/ctk_library_options.cmake should look like:
  345. #
  346. # SET(ctk_library_options
  347. # OPT1:OFF
  348. # OPT2:ON
  349. # )
  350. # Build options associated with CTK libraries
  351. SET(ctk_lib_options_list) # This list will be updated in ctkFunctionExtractOptionNameAndValue
  352. FOREACH(lib ${CTK_LIBS})
  353. ctkFunctionExtractOptionNameAndValue(${lib} lib_name lib_value)
  354. OPTION(CTK_LIB_${lib_name} "Enable ${lib_name} Library." ${lib_value})
  355. ctkMacroAddCtkLibraryOptions(${lib_name})
  356. LIST(APPEND CTK_LIBS_SUBDIRS "${lib_name}")
  357. ENDFOREACH()
  358. # Build options associated with CTK plugins
  359. FOREACH(plugin ${CTK_PLUGINS})
  360. ctkFunctionExtractOptionNameAndValue(${plugin} plugin_name plugin_value)
  361. OPTION(CTK_PLUGIN_${plugin_name} "Build ${plugin_name} Plugin." ${plugin_value})
  362. LIST(APPEND CTK_PLUGINS_SUBDIRS "${plugin_name}")
  363. ENDFOREACH()
  364. # Create a file with variables containing the paths to the source, binary, and library directory
  365. # of each enabled plugin. This is needed to setup include and library dependencies to other plugins
  366. #SET(CTK_PLUGIN_LIST "${CMAKE_CURRENT_BINARY_DIR}/ctkPluginList.cmake")
  367. #SET(CTK_PLUGINS_SUBDIRS_ENABLED )
  368. #FOREACH(plugin ${CTK_PLUGINS_SUBDIRS})
  369. # IF (CTK_PLUGIN_${plugin})
  370. # LIST(APPEND CTK_PLUGINS_SUBDIRS_ENABLED Plugins/${plugin})
  371. # ENDIF()
  372. #ENDFOREACH()
  373. #ctkMacroGeneratePluginList(FILE ${CTK_PLUGIN_LIST}
  374. # DIRECTORIES ${CTK_PLUGINS_SUBDIRS_ENABLED})
  375. # Build options associated with CTK applications
  376. FOREACH(app ${CTK_APPLICATIONS})
  377. ctkFunctionExtractOptionNameAndValue(${app} app_name app_value)
  378. OPTION(CTK_APP_${app_name} "Build ${app_name} Application." ${app_value})
  379. LIST(APPEND CTK_APPLICATIONS_SUBDIRS "${app_name}")
  380. ENDFOREACH()
  381. #-----------------------------------------------------------------------------
  382. # Generate target_directories list - List of directory corresponding to the different
  383. # libraries, plugins and applications associated with the corresponding option name.
  384. #
  385. # Create list of directories corresponding to the enabled targets
  386. SET(target_directories)
  387. FOREACH(lib ${CTK_LIBS_SUBDIRS})
  388. SET(option_name CTK_LIB_${lib})
  389. LIST(APPEND target_directories "${CMAKE_CURRENT_SOURCE_DIR}/Libs/${lib}^^${option_name}")
  390. ENDFOREACH()
  391. FOREACH(plugin ${CTK_PLUGINS_SUBDIRS})
  392. SET(option_name CTK_PLUGIN_${plugin})
  393. LIST(APPEND target_directories "${CMAKE_CURRENT_SOURCE_DIR}/Plugins/${plugin}^^${option_name}")
  394. ENDFOREACH()
  395. FOREACH(app ${CTK_APPLICATIONS_SUBDIRS})
  396. SET(option_name CTK_APP_${app})
  397. LIST(APPEND target_directories "${CMAKE_CURRENT_SOURCE_DIR}/Applications/${app}^^${option_name}")
  398. ENDFOREACH()
  399. #MESSAGE(STATUS target_directories:${target_directories})
  400. #-----------------------------------------------------------------------------
  401. # Compile DGraph - An application allowing to check for cycle in DAG and also obtain the
  402. # topological order.
  403. TRY_COMPILE(RESULT_VAR ${CTK_BINARY_DIR}/Utilities/DGraph ${CTK_SOURCE_DIR}/Utilities/DGraph
  404. DGraph
  405. CMAKE_FLAGS
  406. -DQT_QMAKE_EXECUTABLE:BOOL=${QT_QMAKE_EXECUTABLE}
  407. -DCMAKE_VERBOSE_MAKEFILE:BOOL=FALSE
  408. OUTPUT_VARIABLE output)
  409. IF(NOT RESULT_VAR)
  410. MESSAGE(FATAL_ERROR "Failed to compile DGraph application.\n${output}")
  411. ENDIF()
  412. FIND_PROGRAM(DGraph_EXECUTABLE DGraph
  413. "${CTK_BINARY_DIR}/Utilities/DGraph/"
  414. "${CTK_BINARY_DIR}/Utilities/DGraph/bin/"
  415. "${CTK_BINARY_DIR}/Utilities/DGraph/Debug/"
  416. "${CTK_BINARY_DIR}/Utilities/DGraph/Release/")
  417. MARK_AS_ADVANCED(DGraph_EXECUTABLE)
  418. #-----------------------------------------------------------------------------
  419. # Let's make sure the enabled/disabled libraries, plugins or applications are coherent
  420. #
  421. ctkFunctionGenerateDGraphInput(${CTK_BINARY_DIR} "${target_directories}")
  422. ctkFunctionGenerateDGraphInput(${CTK_BINARY_DIR} "${target_directories}" WITH_EXTERNALS)
  423. ctkMacroValidateBuildOptions("${CTK_BINARY_DIR}" "${DGraph_EXECUTABLE}" "${target_directories}")
  424. #-----------------------------------------------------------------------------
  425. # CTK Python wrapping - Propose the option only if CTK_LIB_Scriping/Python/Core is ON
  426. IF(CTK_LIB_Scripting/Python/Core)
  427. find_package(PythonInterp)
  428. IF(NOT PYTHONINTERP_FOUND)
  429. MESSAGE(SEND_ERROR "PYTHON_EXECUTABLE variable should be set to build CTK_LIB_Scripting/Python")
  430. ENDIF()
  431. FIND_PACKAGE(PythonLibs)
  432. IF(NOT PYTHONLIBS_FOUND)
  433. MESSAGE(FATAL_ERROR "PYTHON_LIBRARIES and PYTHON_INCLUDE_DIRS should be set to build CTK_LIB_Scripting/Python")
  434. ENDIF()
  435. OPTION(CTK_WRAP_PYTHONQT_FULL "Wrap CTK classes using Qt meta-object system into Python language" OFF)
  436. OPTION(CTK_WRAP_PYTHONQT_LIGHT "Wrap CTK classes using Qt meta-object system into Python language" OFF)
  437. IF(CTK_WRAP_PYTHONQT_FULL AND CTK_WRAP_PYTHONQT_LIGHT)
  438. MESSAGE(SEND_ERROR "CTK_WRAP_PYTHONQT_{LIGHT,FULL} options are mutually exclusive. Please enable only one !")
  439. ENDIF()
  440. ELSE()
  441. # Note that an unset boolean variable is considered to be False
  442. UNSET(CTK_WRAP_PYTHONQT_FULL CACHE)
  443. UNSET(CTK_WRAP_PYTHONQT_LIGHT CACHE)
  444. ENDIF()
  445. #-----------------------------------------------------------------------------
  446. # DGraph
  447. #
  448. # Generate DGraph input file expected by DGraph
  449. ctkFunctionGenerateDGraphInput(${CTK_BINARY_DIR} "${target_directories}" WITH_OPTION)
  450. # Obtain list of target ordered topologically
  451. ctkMacroSetPaths("${QT_INSTALLED_LIBRARY_DIR}")
  452. EXECUTE_PROCESS(
  453. COMMAND "${DGraph_EXECUTABLE}" "${CTK_BINARY_DIR}/DGraphInput.txt"
  454. WORKING_DIRECTORY ${CTK_BINARY_DIR}
  455. RESULT_VARIABLE RESULT_VAR
  456. OUTPUT_VARIABLE CTEST_PROJECT_SUBPROJECTS_OUTPUT
  457. ERROR_VARIABLE error
  458. OUTPUT_STRIP_TRAILING_WHITESPACE
  459. )
  460. IF(RESULT_VAR)
  461. MESSAGE(FATAL_ERROR "Failed to obtain list of target ordered topologically.\n${RESULT_VAR}\n${CTK_BINARY_DIR}\n${error}")
  462. ENDIF()
  463. # Convert 'CTEST_PROJECT_SUBPROJECTS_OUTPUT' to a list
  464. STRING(REPLACE " " "\\;" CTEST_PROJECT_SUBPROJECTS "${CTEST_PROJECT_SUBPROJECTS_OUTPUT}")
  465. SET(CTEST_PROJECT_SUBPROJECTS ${CTEST_PROJECT_SUBPROJECTS})
  466. # If the list of subproject is empty, let's at least build CTKCore
  467. LIST(LENGTH CTEST_PROJECT_SUBPROJECTS subproject_count)
  468. IF (subproject_count EQUAL 0)
  469. SET(CTEST_PROJECT_SUBPROJECTS CTKCore)
  470. ENDIF()
  471. # Configure CTestConfigSubProject.cmake used that could be used by CTest scripts
  472. CONFIGURE_FILE(${CTK_SOURCE_DIR}/CTestConfigSubProject.cmake.in
  473. ${CTK_BINARY_DIR}/CTestConfigSubProject.cmake)
  474. #-----------------------------------------------------------------------------
  475. # Project.xml
  476. #
  477. # Generate Project.xml file expected by the CTest driver script
  478. ctkFunctionGenerateProjectXml(${CTK_BINARY_DIR} ${PROJECT_NAME} "${target_directories}" ${CTK_SUPERBUILD})
  479. #-----------------------------------------------------------------------------
  480. # Superbuild script
  481. #
  482. IF(CTK_SUPERBUILD)
  483. INCLUDE("${CMAKE_CURRENT_SOURCE_DIR}/SuperBuild.cmake")
  484. RETURN()
  485. ENDIF()
  486. #-----------------------------------------------------------------------------
  487. # Expand variables containing include directories for external projects
  488. # This relies on the variable EXTERNAL_TARGETS set in ctkMacroValidateBuildOptions
  489. FOREACH(_external_target ${EXTERNAL_TARGETS})
  490. IF(${_external_target}_FIND_PACKAGE_CMD)
  491. #MESSAGE("Calling FIND_PACKAGE(${${_external_target}_FIND_PACKAGE_CMD})")
  492. FIND_PACKAGE(${${_external_target}_FIND_PACKAGE_CMD} REQUIRED)
  493. ENDIF()
  494. ENDFOREACH()
  495. FOREACH(_external_target ${EXTERNAL_TARGETS})
  496. IF(${_external_target}_INCLUDE_DIRS)
  497. STRING(REPLACE "^" ";" _include_variable_list "${${_external_target}_INCLUDE_DIRS}")
  498. IF(_include_variable_list)
  499. #MESSAGE("[${_external_target}] Resolving include variables: ${${_external_target}_INCLUDE_DIRS}")
  500. SET(${_external_target}_INCLUDE_DIRS "")
  501. FOREACH(_include_variable ${_include_variable_list})
  502. #MESSAGE("[${_external_target}] Appending ${${_include_variable}}")
  503. IF(${_include_variable})
  504. LIST(APPEND ${_external_target}_INCLUDE_DIRS ${${_include_variable}})
  505. ELSE()
  506. LIST(APPEND ${_external_target}_INCLUDE_DIRS ${_include_variable})
  507. ENDIF()
  508. #MESSAGE("[${_external_target}] New dirs: ${${_external_target}_INCLUDE_DIRS}")
  509. ENDFOREACH()
  510. #MESSAGE("[${_external_target}] Appended dirs: ${${_external_target}_INCLUDE_DIRS}")
  511. ENDIF()
  512. ENDIF()
  513. ENDFOREACH()
  514. # Since PYTHONQT_USE_VTK library option can be enabled independently of
  515. # Visualization/VTK/Core, let's make sure VTK has been properly discovered
  516. IF(CTK_LIB_Scripting/Python/Core_PYTHONQT_USE_VTK)
  517. FIND_PACKAGE(VTK REQUIRED)
  518. ENDIF()
  519. SET(CTK_WRAP_PYTHONQT_USE_VTK ${CTK_LIB_Scripting/Python/Core_PYTHONQT_USE_VTK})
  520. #-----------------------------------------------------------------------------
  521. # CTK_SUPERBUILD_BINARY_DIR
  522. # If CTK_SUPERBUILD_BINARY_DIR isn't defined, it means CTK is *NOT* build using Superbuild.
  523. # In that specific case, CTK_SUPERBUILD_BINARY_DIR should default to CTK_BINARY_DIR
  524. IF(NOT DEFINED CTK_SUPERBUILD_BINARY_DIR)
  525. SET(CTK_SUPERBUILD_BINARY_DIR ${CTK_BINARY_DIR})
  526. ENDIF()
  527. #-----------------------------------------------------------------------------
  528. # Configure files with settings
  529. #
  530. CONFIGURE_FILE(${CTK_SOURCE_DIR}/UseCTK.cmake.in
  531. ${CTK_SUPERBUILD_BINARY_DIR}/UseCTK.cmake COPYONLY IMMEDIATE)
  532. #-----------------------------------------------------------------------------
  533. # Set C/CXX Flags
  534. #
  535. SET(CMAKE_CXX_FLAGS ${CTK_CXX_FLAGS} CACHE STRING "CMake C Flags" FORCE)
  536. SET(CMAKE_C_FLAGS ${CTK_C_FLAGS} CACHE STRING "CMake CXX Flags" FORCE)
  537. #-----------------------------------------------------------------------------
  538. # Set the header template which defines custom export/import macros
  539. # for shared libraries
  540. #
  541. SET(CTK_EXPORT_HEADER_TEMPLATE "${CTK_SOURCE_DIR}/Libs/ctkExport.h.in")
  542. #-----------------------------------------------------------------------------
  543. # Add CTK library subdirectories
  544. #
  545. FOREACH(lib ${CTK_LIBS_SUBDIRS})
  546. IF (CTK_LIB_${lib})
  547. ADD_SUBDIRECTORY(Libs/${lib})
  548. ENDIF()
  549. ENDFOREACH()
  550. #-----------------------------------------------------------------------------
  551. # Add CTK plugin subdirectories
  552. #
  553. FOREACH(plugin ${CTK_PLUGINS_SUBDIRS})
  554. IF(CTK_PLUGIN_${plugin})
  555. ADD_SUBDIRECTORY(Plugins/${plugin})
  556. ENDIF()
  557. ENDFOREACH()
  558. #-----------------------------------------------------------------------------
  559. # Add CTK application subdirectories
  560. #
  561. FOREACH(app ${CTK_APPLICATIONS_SUBDIRS})
  562. IF (CTK_APP_${app})
  563. ADD_SUBDIRECTORY(Applications/${app})
  564. ENDIF()
  565. ENDFOREACH()
  566. IF(BUILD_TESTING)
  567. ADD_SUBDIRECTORY(Applications/Testing)
  568. ENDIF(BUILD_TESTING)
  569. #-----------------------------------------------------------------------------
  570. # Add general purpose subdirectories
  571. #
  572. #ADD_SUBDIRECTORY(Testing)
  573. #ADD_SUBDIRECTORY(Examples)
  574. #-----------------------------------------------------------------------------
  575. # Style Checking configuration
  576. #
  577. INCLUDE(Utilities/KWStyle/KWStyle.cmake)
  578. #---------------------------------------------------------------------------
  579. # Documentation
  580. #
  581. ADD_SUBDIRECTORY( Documentation )
  582. #-----------------------------------------------------------------------------
  583. # The commands in this directory are intended to be executed as
  584. # the end of the whole configuration process, as a "last step".
  585. # This directory is typically the last SUBDIRS in the main CMakeLists.txt.
  586. ADD_SUBDIRECTORY(Utilities/LastConfigureStep)