CMakeLists.txt 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524
  1. ###########################################################################
  2. #
  3. # Library: CTK
  4. #
  5. # Copyright (c) 2010 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)
  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. # Install directories, used for install rules.
  82. #
  83. SET(CTK_INSTALL_BIN_DIR "bin")
  84. SET(CTK_INSTALL_LIB_DIR "lib")
  85. SET(CTK_INSTALL_INCLUDE_DIR "include")
  86. SET(CTK_INSTALL_DOC_DIR "doc")
  87. #-----------------------------------------------------------------------------
  88. # CTK version number. An even minor number corresponds to releases.
  89. #
  90. SET(CTK_MAJOR_VERSION 0)
  91. SET(CTK_MINOR_VERSION 1)
  92. SET(CTK_BUILD_VERSION 0)
  93. SET(CTK_VERSION
  94. "${CTK_MAJOR_VERSION}.${CTK_MINOR_VERSION}.${CTK_BUILD_VERSION}")
  95. # Append the library version information to the library target
  96. # properties. A parent project may set its own properties and/or may
  97. # block this.
  98. IF(NOT CTK_NO_LIBRARY_VERSION)
  99. SET(CTK_LIBRARY_PROPERTIES ${CTK_LIBRARY_PROPERTIES}
  100. VERSION "${CTK_VERSION}"
  101. SOVERSION "${CTK_MAJOR_VERSION}.${CTK_MINOR_VERSION}"
  102. )
  103. ENDIF()
  104. #-----------------------------------------------------------------------------
  105. # Update CMake module path
  106. # Note: FindXXX.cmake script specific to utility should be copied into Utilities/CMake
  107. #
  108. SET(CMAKE_MODULE_PATH
  109. "${CMAKE_CURRENT_SOURCE_DIR}/Utilities/CMake"
  110. "${CMAKE_CURRENT_SOURCE_DIR}/CMake"
  111. ${CMAKE_MODULE_PATH})
  112. #-----------------------------------------------------------------------------
  113. # Clear CTK_BASE_INCLUDE_DIRS and CTK_BASE_LIBRARIES
  114. #
  115. SET(CTK_BASE_LIBRARIES CACHE INTERNAL "CTK base libraries" FORCE)
  116. SET(CTK_BASE_INCLUDE_DIRS CACHE INTERNAL "CTK includes" FORCE)
  117. # Variable use in CTKConfig.cmake.in
  118. SET(CTK_LIBRARIES CACHE INTERNAL "CTK libraries" FORCE)
  119. #-----------------------------------------------------------------------------
  120. # CMake Function(s) and Macro(s)
  121. #
  122. INCLUDE(CMake/ctkMacroParseArguments.cmake)
  123. INCLUDE(CMake/ctkMacroListFilter.cmake)
  124. INCLUDE(CMake/ctkMacroBuildLib.cmake)
  125. INCLUDE(CMake/ctkMacroBuildPlugin.cmake)
  126. INCLUDE(CMake/ctkMacroBuildApp.cmake)
  127. INCLUDE(CMake/ctkMacroBuildQtDesignerPlugin.cmake)
  128. INCLUDE(CMake/ctkMacroSetupQt.cmake)
  129. INCLUDE(CMake/ctkMacroTargetLibraries.cmake) # Import multiple macros
  130. INCLUDE(CMake/ctkFunctionExtractOptionNameAndValue.cmake)
  131. INCLUDE(CMake/ctkFunctionExecuteProcess.cmake)
  132. INCLUDE(CMake/ctkMacroValidateBuildOptions.cmake)
  133. INCLUDE(CMake/ctkMacroAddCtkLibraryOptions.cmake)
  134. INCLUDE(CMake/ctkFunctionGenerateDGraphInput.cmake)
  135. INCLUDE(CMake/ctkFunctionGenerateProjectXml.cmake)
  136. INCLUDE(CMake/ctkMacroGeneratePluginManifest.cmake)
  137. INCLUDE(CMake/ctkMacroGeneratePluginResourceFile.cmake)
  138. INCLUDE(CMake/ctkFunctionCheckCompilerFlags.cmake)
  139. # Used by CTKGenerateCTKConfig.cmake
  140. SET(CTK_CMAKE_DIR ${CTK_SOURCE_DIR}/CMake)
  141. SET(CTK_CMAKE_UTILITIES_DIR ${CTK_SOURCE_DIR}/Utilities/CMake)
  142. #-----------------------------------------------------------------------------
  143. # Testing
  144. #
  145. OPTION(BUILD_TESTING "Test the project" ON)
  146. IF(BUILD_TESTING)
  147. ENABLE_TESTING()
  148. INCLUDE(CTest)
  149. SET(CPP_TEST_PATH ${CMAKE_RUNTIME_OUTPUT_DIRECTORY})
  150. MARK_AS_ADVANCED(TCL_TCLSH DART_ROOT)
  151. # Setup file for setting custom ctest vars
  152. CONFIGURE_FILE(
  153. CMake/CTestCustom.cmake.in
  154. ${CMAKE_CURRENT_BINARY_DIR}/CTestCustom.cmake
  155. @ONLY
  156. )
  157. # Configuration for the CMake-generated test driver
  158. SET(CMAKE_TESTDRIVER_EXTRA_INCLUDES "#include <stdexcept>")
  159. SET(CMAKE_TESTDRIVER_BEFORE_TESTMAIN "
  160. try
  161. {")
  162. SET(CMAKE_TESTDRIVER_AFTER_TESTMAIN " }
  163. catch( std::exception & excp )
  164. {
  165. fprintf(stderr,\"%s\\n\",excp.what());
  166. return EXIT_FAILURE;
  167. }
  168. catch( ... )
  169. {
  170. printf(\"Exception caught in the test driver\\n\");
  171. return EXIT_FAILURE;
  172. }
  173. ")
  174. ENDIF()
  175. #-----------------------------------------------------------------------------
  176. # Coverage
  177. #
  178. OPTION(WITH_COVERAGE "Enable/Disable coverage" OFF)
  179. #-----------------------------------------------------------------------------
  180. # Documentation
  181. #
  182. OPTION(DOCUMENTATION_TARGET_IN_ALL "Include the custom target for building documentation in 'all'" OFF)
  183. MARK_AS_ADVANCED(DOCUMENTATION_TARGET_IN_ALL)
  184. OPTION(DOCUMENTATION_ARCHIVES_OUTPUT_DIRECTORY "Where documentation archives should be stored" ${CMAKE_CURRENT_BINARY_DIR})
  185. MARK_AS_ADVANCED(DOCUMENTATION_ARCHIVES_OUTPUT_DIRECTORY)
  186. #-----------------------------------------------------------------------------
  187. # Additional CXX/C Flags
  188. #
  189. SET(ADDITIONAL_C_FLAGS "" CACHE STRING "Additional C Flags")
  190. MARK_AS_ADVANCED(ADDITIONAL_C_FLAGS)
  191. SET(ADDITIONAL_CXX_FLAGS "" CACHE STRING "Additional CXX Flags")
  192. MARK_AS_ADVANCED(ADDITIONAL_CXX_FLAGS)
  193. #-----------------------------------------------------------------------------
  194. # Set symbol visibility Flags
  195. #
  196. IF(CMAKE_CXX_COMPILER_ID)
  197. # Set the default symbol visibility to hidden for gcc
  198. IF(${CMAKE_CXX_COMPILER_ID} STREQUAL "GNU")
  199. SET(VISIBILITY_CXX_FLAGS "-fvisibility=hidden -fvisibility-inlines-hidden")
  200. ENDIF()
  201. ENDIF()
  202. #-----------------------------------------------------------------------------
  203. # Set coverage Flags
  204. #
  205. IF(WITH_COVERAGE)
  206. IF(${CMAKE_CXX_COMPILER_ID} STREQUAL "GNU")
  207. SET(coverage_flags "-g -fprofile-arcs -ftest-coverage -O3 -DNDEBUG")
  208. SET(COVERAGE_CXX_FLAGS ${coverage_flags})
  209. SET(COVERAGE_C_FLAGS ${coverage_flags})
  210. ENDIF()
  211. ENDIF()
  212. #-----------------------------------------------------------------------------
  213. # CTK C/CXX Flags
  214. #
  215. SET(CTK_C_FLAGS "${COVERAGE_C_FLAGS} ${ADDITIONAL_C_FLAGS}")
  216. SET(CTK_CXX_FLAGS "${VISIBILITY_CXX_FLAGS} ${COVERAGE_CXX_FLAGS} ${ADDITIONAL_CXX_FLAGS}")
  217. IF(${CMAKE_CXX_COMPILER_ID} STREQUAL "GNU")
  218. SET(cflags "-Wall -Wextra -Wpointer-arith -Winvalid-pch -Wcast-align -Wwrite-strings -D_FORTIFY_SOURCE=2")
  219. ctkFunctionCheckCompilerFlags("-fdiagnostics-show-option" cflags)
  220. ctkFunctionCheckCompilerFlags("-fstack-protector-all" cflags)
  221. SET(CTK_C_FLAGS "${cflags} ${CTK_C_FLAGS}")
  222. SET(CTK_CXX_FLAGS "${cflags} -Woverloaded-virtual -Wold-style-cast -Wstrict-null-sentinel -Wsign-promo ${CTK_CXX_FLAGS}")
  223. ENDIF()
  224. #-----------------------------------------------------------------------------
  225. # QT
  226. #
  227. ctkMacroSetupQt()
  228. # Update CTK_BASE_LIBRARIES with QT libraries
  229. IF(QT4_FOUND)
  230. SET(CTK_BASE_LIBRARIES ${CTK_BASE_LIBRARIES} ${QT_LIBRARIES} CACHE INTERNAL "CTK base libraries" FORCE)
  231. ENDIF()
  232. #-----------------------------------------------------------------------------
  233. # CTK Libraries - Use ON or OFF to indicate if the library should be built by default
  234. #
  235. SET(CTK_LIBS
  236. Core:ON
  237. PluginFramework:ON
  238. Widgets:OFF
  239. DICOM/Core:OFF
  240. DICOM/Widgets:OFF
  241. Messaging/Core:OFF
  242. Scripting/Python/Core:OFF
  243. Scripting/Python/Widgets:OFF
  244. Visualization/VTK/Core:OFF
  245. Visualization/VTK/Widgets:OFF
  246. Visualization/XIP:OFF
  247. )
  248. #-----------------------------------------------------------------------------
  249. # CTK Plugins - Use ON or OFF to indicate if the plugin should be built by default
  250. #
  251. SET(CTK_PLUGINS
  252. org.commontk.eventbus:ON
  253. org.commontk.cli:OFF
  254. )
  255. #-----------------------------------------------------------------------------
  256. # CTK Applications - Use ON or OFF to indicate if the application should be built by default
  257. #
  258. SET(CTK_APPLICATIONS
  259. ctkCLIPluginExplorer:OFF
  260. ctkDICOM:OFF
  261. ctkDICOMIndexer:OFF
  262. ctkDICOMDemoSCU:OFF
  263. ctkDICOMQuery:OFF
  264. ctkDICOMRetrieve:OFF
  265. ctkPluginBrowser:OFF
  266. )
  267. #-----------------------------------------------------------------------------
  268. # To make options show up in both CTK-SuperBuild and CTK regular build, let's add them
  269. # before the SuperBuild script is included
  270. #
  271. # Let's mark as advanced some default properties
  272. MARK_AS_ADVANCED(CMAKE_INSTALL_PREFIX)
  273. MARK_AS_ADVANCED(DART_TESTING_TIMEOUT)
  274. # KWStyle
  275. OPTION(CTK_USE_KWSTYLE "Enable sourcecode-based style tests." OFF)
  276. #MARK_AS_ADVANCED(CTK_USE_KWSTYLE)
  277. #---------------------------------------------------------------------------
  278. # Will contain a list of sub-directory without option ON or OFF
  279. #
  280. SET(CTK_LIBS_SUBDIRS )
  281. SET(CTK_PLUGINS_SUBDIRS )
  282. SET(CTK_APPLICATIONS_SUBDIRS )
  283. #-----------------------------------------------------------------------------
  284. # Build options associated with CTK libraries
  285. # Note also that if
  286. # the file Libs/<DIR>/<LIBNAME>/ctk_library_options.cmake exists and look like:
  287. #
  288. # SET(ctk_library_options
  289. # OPT1:OFF
  290. # OPT2:ON
  291. # )
  292. #
  293. # In addition to 'CTK_LIB_<DIR>/<LIBNAME>' option, the following ones
  294. # will also be available in CMake configure menu:
  295. # CTK_LIB_<DIR>/<LIBNAME>_OPT1 (set to OFF)
  296. # CTK_LIB_<DIR>/<LIBNAME>_OPT2 (set to ON)
  297. #
  298. FOREACH(lib ${CTK_LIBS})
  299. ctkFunctionExtractOptionNameAndValue(${lib} lib_name lib_value)
  300. OPTION(CTK_LIB_${lib_name} "Enable ${lib_name} Library." ${lib_value})
  301. ctkMacroAddCtkLibraryOptions(${lib_name})
  302. LIST(APPEND CTK_LIBS_SUBDIRS "${lib_name}")
  303. ENDFOREACH()
  304. # Build options associated with CTK plugins
  305. FOREACH(plugin ${CTK_PLUGINS})
  306. ctkFunctionExtractOptionNameAndValue(${plugin} plugin_name plugin_value)
  307. OPTION(CTK_PLUGIN_${plugin_name} "Build ${plugin_name} Plugin." ${plugin_value})
  308. LIST(APPEND CTK_PLUGINS_SUBDIRS "${plugin_name}")
  309. ENDFOREACH()
  310. # Build options associated with CTK applications
  311. FOREACH(app ${CTK_APPLICATIONS})
  312. ctkFunctionExtractOptionNameAndValue(${app} app_name app_value)
  313. OPTION(CTK_APP_${app_name} "Build ${app_name} Application." ${app_value})
  314. LIST(APPEND CTK_APPLICATIONS_SUBDIRS "${app_name}")
  315. ENDFOREACH()
  316. #-----------------------------------------------------------------------------
  317. # Generate target_directories list - List of directory corresponding to the different
  318. # libraries, plugins and applications associated with the corresponding option name.
  319. #
  320. # Create list of directories corresponding to the enabled targets
  321. SET(target_directories)
  322. FOREACH(lib ${CTK_LIBS_SUBDIRS})
  323. SET(option_name CTK_LIB_${lib})
  324. LIST(APPEND target_directories "${CMAKE_CURRENT_SOURCE_DIR}/Libs/${lib}^^${option_name}")
  325. ENDFOREACH()
  326. FOREACH(plugin ${CTK_PLUGINS_SUBDIRS})
  327. SET(option_name CTK_PLUGIN_${plugin})
  328. LIST(APPEND target_directories "${CMAKE_CURRENT_SOURCE_DIR}/Plugins/${plugin}^^${option_name}")
  329. ENDFOREACH()
  330. FOREACH(app ${CTK_APPLICATIONS_SUBDIRS})
  331. SET(option_name CTK_APP_${app})
  332. LIST(APPEND target_directories "${CMAKE_CURRENT_SOURCE_DIR}/Applications/${app}^^${option_name}")
  333. ENDFOREACH()
  334. #MESSAGE(STATUS target_directories:${target_directories})
  335. #-----------------------------------------------------------------------------
  336. # Compile DGraph - An application allowing to check for cycle in DAG and also obtain the
  337. # topological order.
  338. TRY_COMPILE(RESULT_VAR ${CTK_BINARY_DIR}/Utilities/DGraph ${CTK_SOURCE_DIR}/Utilities/DGraph
  339. DGraph
  340. CMAKE_FLAGS
  341. -DQT_QMAKE_EXECUTABLE:BOOL=${QT_QMAKE_EXECUTABLE}
  342. -DCMAKE_VERBOSE_MAKEFILE:BOOL=FALSE
  343. OUTPUT_VARIABLE output)
  344. IF(NOT RESULT_VAR)
  345. MESSAGE(FATAL_ERROR "Failed to compile DGraph application.\n${output}")
  346. ENDIF()
  347. FIND_PROGRAM(DGraph_EXECUTABLE DGraph
  348. "${CTK_BINARY_DIR}/Utilities/DGraph/"
  349. "${CTK_BINARY_DIR}/Utilities/DGraph/bin/"
  350. "${CTK_BINARY_DIR}/Utilities/DGraph/Debug/"
  351. "${CTK_BINARY_DIR}/Utilities/DGraph/Release/")
  352. MARK_AS_ADVANCED(DGraph_EXECUTABLE)
  353. #-----------------------------------------------------------------------------
  354. # Let's make sure the enabled/disabled libraries, plugins or applications are coherent
  355. #
  356. ctkFunctionGenerateDGraphInput(${CTK_BINARY_DIR} "${target_directories}" FALSE)
  357. ctkMacroValidateBuildOptions("${CTK_BINARY_DIR}" "${DGraph_EXECUTABLE}" "${target_directories}")
  358. #-----------------------------------------------------------------------------
  359. # DGraph
  360. #
  361. # Generate DGraph input file expected by DGraph
  362. ctkFunctionGenerateDGraphInput(${CTK_BINARY_DIR} "${target_directories}" TRUE)
  363. # Obtain list of target ordered topologically
  364. ctkFunctionExecuteProcess(
  365. COMMAND "${DGraph_EXECUTABLE}" "${CTK_BINARY_DIR}/DGraphInput.txt"
  366. PATH_LIST \"${QT_INSTALLED_LIBRARY_DIR}\"
  367. WORKING_DIRECTORY ${CTK_BINARY_DIR}
  368. RESULT_VARIABLE RESULT_VAR
  369. OUTPUT_VARIABLE CTEST_PROJECT_SUBPROJECTS
  370. ERROR_VARIABLE error
  371. OUTPUT_STRIP_TRAILING_WHITESPACE
  372. )
  373. IF(RESULT_VAR)
  374. MESSAGE(FATAL_ERROR "Failed to obtain list of target ordered topologically.\n${RESULT_VAR}\n${CTK_BINARY_DIR}\n${error}")
  375. ENDIF()
  376. # If the list of subproject is empty, let's at least build CTKCore
  377. LIST(LENGTH CTEST_PROJECT_SUBPROJECTS subproject_count)
  378. IF (subproject_count EQUAL 0)
  379. SET(CTEST_PROJECT_SUBPROJECTS CTKCore)
  380. ENDIF()
  381. # Configure CTestConfigSubProject.cmake used that could be used by CTest scripts
  382. CONFIGURE_FILE(${CTK_SOURCE_DIR}/CTestConfigSubProject.cmake.in
  383. ${CTK_BINARY_DIR}/CTestConfigSubProject.cmake)
  384. #-----------------------------------------------------------------------------
  385. # Project.xml
  386. #
  387. # Generate Project.xml file expected by the CTest driver script
  388. ctkFunctionGenerateProjectXml(${CTK_BINARY_DIR} ${PROJECT_NAME} "${target_directories}" ${CTK_SUPERBUILD})
  389. #-----------------------------------------------------------------------------
  390. # Superbuild script
  391. #
  392. IF(CTK_SUPERBUILD)
  393. INCLUDE("${CMAKE_CURRENT_SOURCE_DIR}/SuperBuild.cmake")
  394. RETURN()
  395. ENDIF()
  396. #-----------------------------------------------------------------------------
  397. # CTK_SUPERBUILD_BINARY_DIR
  398. # If CTK_SUPERBUILD_BINARY_DIR isn't defined, it means CTK is *NOT* build using Superbuild.
  399. # In that specific case, CTK_SUPERBUILD_BINARY_DIR should default to CTK_BINARY_DIR
  400. IF(NOT DEFINED CTK_SUPERBUILD_BINARY_DIR)
  401. SET(CTK_SUPERBUILD_BINARY_DIR ${CTK_BINARY_DIR})
  402. ENDIF()
  403. #-----------------------------------------------------------------------------
  404. # Configure files with settings
  405. #
  406. CONFIGURE_FILE(${CTK_SOURCE_DIR}/UseCTK.cmake.in
  407. ${CTK_SUPERBUILD_BINARY_DIR}/UseCTK.cmake COPYONLY IMMEDIATE)
  408. #-----------------------------------------------------------------------------
  409. # Set C/CXX Flags
  410. #
  411. SET(CMAKE_CXX_FLAGS ${CTK_CXX_FLAGS} CACHE STRING "CMake C Flags" FORCE)
  412. SET(CMAKE_C_FLAGS ${CTK_C_FLAGS} CACHE STRING "CMake CXX Flags" FORCE)
  413. #-----------------------------------------------------------------------------
  414. # Add CTK library subdirectories
  415. #
  416. FOREACH(lib ${CTK_LIBS_SUBDIRS})
  417. IF (CTK_LIB_${lib})
  418. ADD_SUBDIRECTORY(Libs/${lib})
  419. ENDIF()
  420. ENDFOREACH()
  421. #-----------------------------------------------------------------------------
  422. # Add CTK plugin subdirectories
  423. #
  424. FOREACH(plugin ${CTK_PLUGINS_SUBDIRS})
  425. IF (CTK_PLUGIN_${plugin})
  426. ADD_SUBDIRECTORY(Plugins/${plugin})
  427. ENDIF()
  428. ENDFOREACH()
  429. #-----------------------------------------------------------------------------
  430. # Add CTK application subdirectories
  431. #
  432. FOREACH(app ${CTK_APPLICATIONS_SUBDIRS})
  433. IF (CTK_APP_${app})
  434. ADD_SUBDIRECTORY(Applications/${app})
  435. ENDIF()
  436. ENDFOREACH()
  437. #-----------------------------------------------------------------------------
  438. # Add general purpose subdirectories
  439. #
  440. #ADD_SUBDIRECTORY(Testing)
  441. #ADD_SUBDIRECTORY(Examples)
  442. #-----------------------------------------------------------------------------
  443. # Style Checking configuration
  444. #
  445. INCLUDE(Utilities/KWStyle/KWStyle.cmake)
  446. #---------------------------------------------------------------------------
  447. # Documentation
  448. #
  449. ADD_SUBDIRECTORY( Documentation )
  450. #-----------------------------------------------------------------------------
  451. # The commands in this directory are intended to be executed as
  452. # the end of the whole configuration process, as a "last step".
  453. # This directory is typically the last SUBDIRS in the main CMakeLists.txt.
  454. ADD_SUBDIRECTORY(Utilities/LastConfigureStep)