CMakeLists.txt 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167
  1. #=============================================================================
  2. # CMake - Cross Platform Makefile Generator
  3. # Copyright 2000-2009 Kitware, Inc., Insight Software Consortium
  4. #
  5. # Distributed under the OSI-approved BSD License (the "License");
  6. # see accompanying file Copyright.txt for details.
  7. #
  8. # This software is distributed WITHOUT ANY WARRANTY; without even the
  9. # implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  10. # See the License for more information.
  11. #=============================================================================
  12. subdirs(Doxygen KWStyle)
  13. make_directory(${CMake_BINARY_DIR}/Docs)
  14. # Add a documentation target.
  15. set(DOC_FILES "")
  16. set(MAN_FILES
  17. ${CMake_BINARY_DIR}/Docs/cmake.1
  18. ${CMake_BINARY_DIR}/Docs/cmakecommands.1
  19. ${CMake_BINARY_DIR}/Docs/cmakecompat.1
  20. ${CMake_BINARY_DIR}/Docs/cmakeprops.1
  21. ${CMake_BINARY_DIR}/Docs/cmakepolicies.1
  22. ${CMake_BINARY_DIR}/Docs/cmakevars.1
  23. ${CMake_BINARY_DIR}/Docs/cmakemodules.1
  24. )
  25. set(TEXT_FILES
  26. ${CMake_BINARY_DIR}/Docs/cmake.txt
  27. ${CMake_BINARY_DIR}/Docs/cmake-policies.txt
  28. ${CMake_BINARY_DIR}/Docs/cmake-properties.txt
  29. ${CMake_BINARY_DIR}/Docs/cmake-variables.txt
  30. ${CMake_BINARY_DIR}/Docs/cmake-modules.txt
  31. ${CMake_BINARY_DIR}/Docs/cmake-commands.txt
  32. ${CMake_BINARY_DIR}/Docs/cmake-compatcommands.txt
  33. )
  34. set(HTML_FILES
  35. ${CMake_BINARY_DIR}/Docs/cmake.html
  36. ${CMake_BINARY_DIR}/Docs/cmake-policies.html
  37. ${CMake_BINARY_DIR}/Docs/cmake-properties.html
  38. ${CMake_BINARY_DIR}/Docs/cmake-variables.html
  39. ${CMake_BINARY_DIR}/Docs/cmake-modules.html
  40. ${CMake_BINARY_DIR}/Docs/cmake-commands.html
  41. ${CMake_BINARY_DIR}/Docs/cmake-compatcommands.html
  42. )
  43. set(DOCBOOK_FILES
  44. ${CMake_BINARY_DIR}/Docs/cmake.docbook
  45. )
  46. macro(ADD_DOCS target dependency)
  47. # Generate documentation for "ctest" executable.
  48. get_target_property(CMD ${target} LOCATION)
  49. # only generate the documentation if the target is actually built
  50. if(CMD)
  51. add_custom_command(
  52. OUTPUT ${CMake_BINARY_DIR}/Docs/${target}.txt
  53. ${${target}-PATH} # Possibly set PATH, see below.
  54. COMMAND ${CMD}
  55. ARGS --help-full ${CMake_BINARY_DIR}/Docs/${target}.txt
  56. --help-full ${CMake_BINARY_DIR}/Docs/${target}.html
  57. --help-full ${CMake_BINARY_DIR}/Docs/${target}.1
  58. --help-full ${CMake_BINARY_DIR}/Docs/${target}.docbook
  59. DEPENDS ${target}
  60. MAIN_DEPENDENCY ${dependency}
  61. )
  62. set(DOC_FILES ${DOC_FILES} ${CMake_BINARY_DIR}/Docs/${target}.txt)
  63. list(APPEND MAN_FILES ${CMake_BINARY_DIR}/Docs/${target}.1)
  64. list(APPEND TEXT_FILES ${CMake_BINARY_DIR}/Docs/${target}.txt)
  65. list(APPEND HTML_FILES ${CMake_BINARY_DIR}/Docs/${target}.html)
  66. list(APPEND DOCBOOK_FILES ${CMake_BINARY_DIR}/Docs/${target}.docbook)
  67. endif()
  68. endmacro()
  69. # Help cmake-gui find the Qt DLLs on Windows.
  70. if(TARGET cmake-gui)
  71. get_property(Qt_BIN_DIR TARGET cmake-gui PROPERTY Qt_BIN_DIR)
  72. set(WIN_SHELL_GENS "Visual Studio|NMake|MinGW|Watcom|Borland")
  73. if(Qt_BIN_DIR AND "${CMAKE_GENERATOR}" MATCHES "${WIN_SHELL_GENS}"
  74. AND NOT CMAKE_NO_AUTO_QT_ENV)
  75. # Tell the macro to set the path before running cmake-gui.
  76. string(REPLACE ";" "\\;" _PATH "PATH=${Qt_BIN_DIR};%PATH%")
  77. set(cmake-gui-PATH COMMAND set "${_PATH}")
  78. endif()
  79. endif()
  80. # add the docs for the executables
  81. ADD_DOCS(ctest ${CMake_SOURCE_DIR}/Utilities/Doxygen/authors.txt)
  82. ADD_DOCS(cpack ${CMake_SOURCE_DIR}/Utilities/Doxygen/authors.txt)
  83. ADD_DOCS(ccmake ${CMake_SOURCE_DIR}/Utilities/Doxygen/authors.txt)
  84. ADD_DOCS(CMakeSetup ${CMake_SOURCE_DIR}/Utilities/Doxygen/doxyfile.in)
  85. ADD_DOCS(cmake-gui ${CMake_SOURCE_DIR}/Utilities/Doxygen/doxyfile.in)
  86. # add the documentation for cmake itself
  87. get_target_property(CMD cmake LOCATION)
  88. add_custom_command(
  89. OUTPUT ${CMake_BINARY_DIR}/Docs/cmake.txt
  90. COMMAND ${CMD}
  91. ARGS --copyright ${CMake_BINARY_DIR}/Docs/Copyright.txt
  92. --help-full ${CMake_BINARY_DIR}/Docs/cmake.txt
  93. --help-full ${CMake_BINARY_DIR}/Docs/cmake.html
  94. --help-full ${CMake_BINARY_DIR}/Docs/cmake.1
  95. --help-full ${CMake_BINARY_DIR}/Docs/cmake.docbook
  96. --help-policies ${CMake_BINARY_DIR}/Docs/cmake-policies.txt
  97. --help-policies ${CMake_BINARY_DIR}/Docs/cmake-policies.html
  98. --help-policies ${CMake_BINARY_DIR}/Docs/cmakepolicies.1
  99. --help-properties ${CMake_BINARY_DIR}/Docs/cmake-properties.txt
  100. --help-properties ${CMake_BINARY_DIR}/Docs/cmake-properties.html
  101. --help-properties ${CMake_BINARY_DIR}/Docs/cmakeprops.1
  102. --help-variables ${CMake_BINARY_DIR}/Docs/cmake-variables.txt
  103. --help-variables ${CMake_BINARY_DIR}/Docs/cmake-variables.html
  104. --help-variables ${CMake_BINARY_DIR}/Docs/cmakevars.1
  105. --help-modules ${CMake_BINARY_DIR}/Docs/cmake-modules.txt
  106. --help-modules ${CMake_BINARY_DIR}/Docs/cmake-modules.html
  107. --help-modules ${CMake_BINARY_DIR}/Docs/cmakemodules.1
  108. --help-commands ${CMake_BINARY_DIR}/Docs/cmake-commands.txt
  109. --help-commands ${CMake_BINARY_DIR}/Docs/cmake-commands.html
  110. --help-commands ${CMake_BINARY_DIR}/Docs/cmakecommands.1
  111. --help-compatcommands ${CMake_BINARY_DIR}/Docs/cmake-compatcommands.txt
  112. --help-compatcommands ${CMake_BINARY_DIR}/Docs/cmake-compatcommands.html
  113. --help-compatcommands ${CMake_BINARY_DIR}/Docs/cmakecompat.1
  114. DEPENDS cmake
  115. MAIN_DEPENDENCY ${CMake_SOURCE_DIR}/Utilities/Doxygen/authors.txt
  116. )
  117. install(FILES ${MAN_FILES} DESTINATION ${CMAKE_MAN_DIR}/man1)
  118. install(FILES
  119. ${TEXT_FILES}
  120. ${HTML_FILES}
  121. ${DOCBOOK_FILES}
  122. DESTINATION ${CMAKE_DOC_DIR}
  123. )
  124. install(FILES cmake.m4 DESTINATION share/aclocal)
  125. # Drive documentation generation.
  126. add_custom_target(documentation ALL DEPENDS ${DOC_FILES} ${CMake_BINARY_DIR}/Docs/cmake.txt )
  127. # Documentation testing.
  128. if(BUILD_TESTING)
  129. find_package(LibXml2 QUIET)
  130. if(NOT DEFINED LIBXML2_XMLLINT_EXECUTABLE)
  131. find_program(LIBXML2_XMLLINT_EXECUTABLE xmllint)
  132. endif()
  133. mark_as_advanced(LIBXML2_XMLLINT_EXECUTABLE)
  134. if(LIBXML2_XMLLINT_EXECUTABLE)
  135. execute_process(COMMAND ${LIBXML2_XMLLINT_EXECUTABLE} --help
  136. OUTPUT_VARIABLE _help ERROR_VARIABLE _err)
  137. if("${_help}" MATCHES "--path" AND "${_help}" MATCHES "--nonet")
  138. # We provide DTDs in the 'xml' directory so that xmllint can run without
  139. # network access. Note that xmllints's --path option accepts a
  140. # space-separated list of url-encoded paths.
  141. set(_dtd_dir "${CMAKE_CURRENT_SOURCE_DIR}/xml")
  142. string(REPLACE " " "%20" _dtd_dir "${_dtd_dir}")
  143. string(REPLACE ":" "%3A" _dtd_dir "${_dtd_dir}")
  144. add_test(CMake.HTML
  145. ${LIBXML2_XMLLINT_EXECUTABLE} --valid --noout --nonet
  146. --path ${_dtd_dir}/xhtml1
  147. ${HTML_FILES}
  148. )
  149. add_test(CMake.DocBook
  150. ${LIBXML2_XMLLINT_EXECUTABLE} --valid --noout --nonet
  151. --path ${_dtd_dir}/docbook-4.5
  152. ${DOCBOOK_FILES}
  153. )
  154. endif()
  155. endif()
  156. endif()