1 #=============================================================================
2 # CMake - Cross Platform Makefile Generator
3 # Copyright 2000-2009 Kitware, Inc., Insight Software Consortium
5 # Distributed under the OSI-approved BSD License (the "License");
6 # see accompanying file Copyright.txt for details.
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)
14 make_directory(${CMake_BINARY_DIR}/Docs)
16 # Add a documentation target.
20 ${CMake_BINARY_DIR}/Docs/cmake.1
21 ${CMake_BINARY_DIR}/Docs/cmakecommands.1
22 ${CMake_BINARY_DIR}/Docs/cmakecompat.1
23 ${CMake_BINARY_DIR}/Docs/cmakeprops.1
24 ${CMake_BINARY_DIR}/Docs/cmakepolicies.1
25 ${CMake_BINARY_DIR}/Docs/cmakevars.1
26 ${CMake_BINARY_DIR}/Docs/cmakemodules.1
29 ${CMake_BINARY_DIR}/Docs/cmake.txt
30 ${CMake_BINARY_DIR}/Docs/cmake-policies.txt
31 ${CMake_BINARY_DIR}/Docs/cmake-properties.txt
32 ${CMake_BINARY_DIR}/Docs/cmake-variables.txt
33 ${CMake_BINARY_DIR}/Docs/cmake-modules.txt
34 ${CMake_BINARY_DIR}/Docs/cmake-commands.txt
35 ${CMake_BINARY_DIR}/Docs/cmake-compatcommands.txt
38 ${CMake_BINARY_DIR}/Docs/cmake.html
39 ${CMake_BINARY_DIR}/Docs/cmake-policies.html
40 ${CMake_BINARY_DIR}/Docs/cmake-properties.html
41 ${CMake_BINARY_DIR}/Docs/cmake-variables.html
42 ${CMake_BINARY_DIR}/Docs/cmake-modules.html
43 ${CMake_BINARY_DIR}/Docs/cmake-commands.html
44 ${CMake_BINARY_DIR}/Docs/cmake-compatcommands.html
47 ${CMake_BINARY_DIR}/Docs/cmake.docbook
50 macro(ADD_DOCS target dependency)
51 # Generate documentation for "ctest" executable.
52 get_target_property(CMD ${target} LOCATION)
53 # only generate the documentation if the target is actually built
56 OUTPUT ${CMake_BINARY_DIR}/Docs/${target}.txt
57 ${${target}-PATH} # Possibly set PATH, see below.
59 ARGS --help-full ${CMake_BINARY_DIR}/Docs/${target}.txt
60 --help-full ${CMake_BINARY_DIR}/Docs/${target}.html
61 --help-full ${CMake_BINARY_DIR}/Docs/${target}.1
62 --help-full ${CMake_BINARY_DIR}/Docs/${target}.docbook
64 MAIN_DEPENDENCY ${dependency}
66 set(DOC_FILES ${DOC_FILES} ${CMake_BINARY_DIR}/Docs/${target}.txt)
67 list(APPEND MAN_FILES ${CMake_BINARY_DIR}/Docs/${target}.1)
68 list(APPEND TEXT_FILES ${CMake_BINARY_DIR}/Docs/${target}.txt)
69 list(APPEND HTML_FILES ${CMake_BINARY_DIR}/Docs/${target}.html)
70 list(APPEND DOCBOOK_FILES ${CMake_BINARY_DIR}/Docs/${target}.docbook)
74 # Help cmake-gui find the Qt DLLs on Windows.
76 get_property(Qt_BIN_DIR TARGET cmake-gui PROPERTY Qt_BIN_DIR)
77 set(WIN_SHELL_GENS "Visual Studio|NMake|MinGW|Watcom|Borland")
78 if(Qt_BIN_DIR AND "${CMAKE_GENERATOR}" MATCHES "${WIN_SHELL_GENS}"
79 AND NOT CMAKE_NO_AUTO_QT_ENV)
80 # Tell the macro to set the path before running cmake-gui.
81 string(REPLACE ";" "\\;" _PATH "PATH=${Qt_BIN_DIR};%PATH%")
82 set(cmake-gui-PATH COMMAND set "${_PATH}")
86 # add the docs for the executables
87 ADD_DOCS(ctest ${CMake_SOURCE_DIR}/Utilities/Doxygen/authors.txt)
88 ADD_DOCS(cpack ${CMake_SOURCE_DIR}/Utilities/Doxygen/authors.txt)
89 ADD_DOCS(ccmake ${CMake_SOURCE_DIR}/Utilities/Doxygen/authors.txt)
90 ADD_DOCS(CMakeSetup ${CMake_SOURCE_DIR}/Utilities/Doxygen/doxyfile.in)
91 ADD_DOCS(cmake-gui ${CMake_SOURCE_DIR}/Utilities/Doxygen/doxyfile.in)
93 # add the documentation for cmake itself
95 get_target_property(CMD cmake LOCATION)
97 OUTPUT ${CMake_BINARY_DIR}/Docs/cmake.txt
99 ARGS --copyright ${CMake_BINARY_DIR}/Docs/Copyright.txt
100 --help-full ${CMake_BINARY_DIR}/Docs/cmake.txt
101 --help-full ${CMake_BINARY_DIR}/Docs/cmake.html
102 --help-full ${CMake_BINARY_DIR}/Docs/cmake.1
103 --help-full ${CMake_BINARY_DIR}/Docs/cmake.docbook
104 --help-policies ${CMake_BINARY_DIR}/Docs/cmake-policies.txt
105 --help-policies ${CMake_BINARY_DIR}/Docs/cmake-policies.html
106 --help-policies ${CMake_BINARY_DIR}/Docs/cmakepolicies.1
107 --help-properties ${CMake_BINARY_DIR}/Docs/cmake-properties.txt
108 --help-properties ${CMake_BINARY_DIR}/Docs/cmake-properties.html
109 --help-properties ${CMake_BINARY_DIR}/Docs/cmakeprops.1
110 --help-variables ${CMake_BINARY_DIR}/Docs/cmake-variables.txt
111 --help-variables ${CMake_BINARY_DIR}/Docs/cmake-variables.html
112 --help-variables ${CMake_BINARY_DIR}/Docs/cmakevars.1
113 --help-modules ${CMake_BINARY_DIR}/Docs/cmake-modules.txt
114 --help-modules ${CMake_BINARY_DIR}/Docs/cmake-modules.html
115 --help-modules ${CMake_BINARY_DIR}/Docs/cmakemodules.1
116 --help-commands ${CMake_BINARY_DIR}/Docs/cmake-commands.txt
117 --help-commands ${CMake_BINARY_DIR}/Docs/cmake-commands.html
118 --help-commands ${CMake_BINARY_DIR}/Docs/cmakecommands.1
119 --help-compatcommands ${CMake_BINARY_DIR}/Docs/cmake-compatcommands.txt
120 --help-compatcommands ${CMake_BINARY_DIR}/Docs/cmake-compatcommands.html
121 --help-compatcommands ${CMake_BINARY_DIR}/Docs/cmakecompat.1
123 MAIN_DEPENDENCY ${CMake_SOURCE_DIR}/Utilities/Doxygen/authors.txt
126 install(FILES ${MAN_FILES} DESTINATION ${CMAKE_MAN_DIR}/man1)
131 DESTINATION ${CMAKE_DOC_DIR}
133 install(FILES cmake.m4 DESTINATION share/aclocal)
135 # Drive documentation generation.
136 add_custom_target(documentation ALL DEPENDS ${DOC_FILES} ${CMake_BINARY_DIR}/Docs/cmake.txt )
138 # Documentation testing.
140 find_package(LibXml2 QUIET)
141 if(NOT DEFINED LIBXML2_XMLLINT_EXECUTABLE)
142 find_program(LIBXML2_XMLLINT_EXECUTABLE xmllint)
144 mark_as_advanced(LIBXML2_XMLLINT_EXECUTABLE)
145 if(LIBXML2_XMLLINT_EXECUTABLE)
146 execute_process(COMMAND ${LIBXML2_XMLLINT_EXECUTABLE} --help
147 OUTPUT_VARIABLE _help ERROR_VARIABLE _err)
148 if("${_help}" MATCHES "--path" AND "${_help}" MATCHES "--nonet")
149 # We provide DTDs in the 'xml' directory so that xmllint can run without
150 # network access. Note that xmllints's --path option accepts a
151 # space-separated list of url-encoded paths.
152 set(_dtd_dir "${CMAKE_CURRENT_SOURCE_DIR}/xml")
153 string(REPLACE " " "%20" _dtd_dir "${_dtd_dir}")
154 string(REPLACE ":" "%3A" _dtd_dir "${_dtd_dir}")
156 ${LIBXML2_XMLLINT_EXECUTABLE} --valid --noout --nonet
157 --path ${_dtd_dir}/xhtml1
160 add_test(CMake.DocBook
161 ${LIBXML2_XMLLINT_EXECUTABLE} --valid --noout --nonet
162 --path ${_dtd_dir}/docbook-4.5