2009-09-28 19:43:28 +04:00
|
|
|
#=============================================================================
|
|
|
|
# CMake - Cross Platform Makefile Generator
|
|
|
|
# Copyright 2000-2009 Kitware, Inc., Insight Software Consortium
|
|
|
|
#
|
|
|
|
# Distributed under the OSI-approved BSD License (the "License");
|
|
|
|
# see accompanying file Copyright.txt for details.
|
|
|
|
#
|
|
|
|
# This software is distributed WITHOUT ANY WARRANTY; without even the
|
|
|
|
# implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
|
|
# See the License for more information.
|
|
|
|
#=============================================================================
|
2012-08-13 21:47:32 +04:00
|
|
|
subdirs(Doxygen KWStyle)
|
2003-07-22 00:38:53 +04:00
|
|
|
|
2012-08-13 21:47:32 +04:00
|
|
|
make_directory(${CMake_BINARY_DIR}/Docs)
|
2003-07-22 01:14:16 +04:00
|
|
|
|
|
|
|
# Add a documentation target.
|
2012-08-13 21:47:32 +04:00
|
|
|
set(DOC_FILES "")
|
2003-07-22 01:14:16 +04:00
|
|
|
|
2012-08-13 21:47:32 +04:00
|
|
|
set(MAN_FILES
|
2010-03-01 16:43:54 +03:00
|
|
|
${CMake_BINARY_DIR}/Docs/cmake.1
|
|
|
|
${CMake_BINARY_DIR}/Docs/cmakecommands.1
|
|
|
|
${CMake_BINARY_DIR}/Docs/cmakecompat.1
|
|
|
|
${CMake_BINARY_DIR}/Docs/cmakeprops.1
|
|
|
|
${CMake_BINARY_DIR}/Docs/cmakepolicies.1
|
|
|
|
${CMake_BINARY_DIR}/Docs/cmakevars.1
|
|
|
|
${CMake_BINARY_DIR}/Docs/cmakemodules.1
|
|
|
|
)
|
2012-08-13 21:47:32 +04:00
|
|
|
set(TEXT_FILES
|
2010-03-01 16:43:54 +03:00
|
|
|
${CMake_BINARY_DIR}/Docs/cmake.txt
|
|
|
|
${CMake_BINARY_DIR}/Docs/cmake-policies.txt
|
|
|
|
${CMake_BINARY_DIR}/Docs/cmake-properties.txt
|
|
|
|
${CMake_BINARY_DIR}/Docs/cmake-variables.txt
|
|
|
|
${CMake_BINARY_DIR}/Docs/cmake-modules.txt
|
|
|
|
${CMake_BINARY_DIR}/Docs/cmake-commands.txt
|
|
|
|
${CMake_BINARY_DIR}/Docs/cmake-compatcommands.txt
|
|
|
|
)
|
2012-08-13 21:47:32 +04:00
|
|
|
set(HTML_FILES
|
2010-03-01 16:43:54 +03:00
|
|
|
${CMake_BINARY_DIR}/Docs/cmake.html
|
|
|
|
${CMake_BINARY_DIR}/Docs/cmake-policies.html
|
|
|
|
${CMake_BINARY_DIR}/Docs/cmake-properties.html
|
|
|
|
${CMake_BINARY_DIR}/Docs/cmake-variables.html
|
|
|
|
${CMake_BINARY_DIR}/Docs/cmake-modules.html
|
|
|
|
${CMake_BINARY_DIR}/Docs/cmake-commands.html
|
|
|
|
${CMake_BINARY_DIR}/Docs/cmake-compatcommands.html
|
|
|
|
)
|
2012-09-07 14:51:59 +04:00
|
|
|
set(DOCBOOK_FILES
|
|
|
|
${CMake_BINARY_DIR}/Docs/cmake.docbook
|
|
|
|
)
|
2010-03-01 16:43:54 +03:00
|
|
|
|
2012-08-13 21:47:32 +04:00
|
|
|
macro(ADD_DOCS target dependency)
|
2007-06-15 16:53:33 +04:00
|
|
|
# Generate documentation for "ctest" executable.
|
2012-08-13 21:47:32 +04:00
|
|
|
get_target_property(CMD ${target} LOCATION)
|
2007-06-15 16:53:33 +04:00
|
|
|
# only generate the documentation if the target is actually built
|
2012-08-13 21:47:32 +04:00
|
|
|
if(CMD)
|
|
|
|
add_custom_command(
|
2007-06-15 16:53:33 +04:00
|
|
|
OUTPUT ${CMake_BINARY_DIR}/Docs/${target}.txt
|
2009-02-24 17:00:42 +03:00
|
|
|
${${target}-PATH} # Possibly set PATH, see below.
|
2007-06-15 16:53:33 +04:00
|
|
|
COMMAND ${CMD}
|
|
|
|
ARGS --help-full ${CMake_BINARY_DIR}/Docs/${target}.txt
|
2007-06-28 19:00:57 +04:00
|
|
|
--help-full ${CMake_BINARY_DIR}/Docs/${target}.html
|
|
|
|
--help-full ${CMake_BINARY_DIR}/Docs/${target}.1
|
2008-05-13 23:43:00 +04:00
|
|
|
--help-full ${CMake_BINARY_DIR}/Docs/${target}.docbook
|
2007-06-15 16:53:33 +04:00
|
|
|
DEPENDS ${target}
|
|
|
|
MAIN_DEPENDENCY ${dependency}
|
|
|
|
)
|
2012-08-13 21:47:32 +04:00
|
|
|
set(DOC_FILES ${DOC_FILES} ${CMake_BINARY_DIR}/Docs/${target}.txt)
|
|
|
|
list(APPEND MAN_FILES ${CMake_BINARY_DIR}/Docs/${target}.1)
|
2012-09-07 14:51:59 +04:00
|
|
|
list(APPEND TEXT_FILES ${CMake_BINARY_DIR}/Docs/${target}.txt)
|
2012-08-13 21:47:32 +04:00
|
|
|
list(APPEND HTML_FILES ${CMake_BINARY_DIR}/Docs/${target}.html)
|
2012-09-07 14:51:59 +04:00
|
|
|
list(APPEND DOCBOOK_FILES ${CMake_BINARY_DIR}/Docs/${target}.docbook)
|
2012-08-13 21:50:14 +04:00
|
|
|
endif()
|
|
|
|
endmacro()
|
2007-06-15 16:53:33 +04:00
|
|
|
|
2009-02-24 17:00:42 +03:00
|
|
|
# Help cmake-gui find the Qt DLLs on Windows.
|
2012-08-13 21:47:32 +04:00
|
|
|
set(WIN_SHELL_GENS "Visual Studio|NMake|MinGW|Watcom|Borland")
|
|
|
|
if(BUILD_QtDialog AND "${CMAKE_GENERATOR}" MATCHES "${WIN_SHELL_GENS}"
|
2009-02-25 01:07:04 +03:00
|
|
|
AND EXISTS "${QT_QMAKE_EXECUTABLE}" AND NOT CMAKE_NO_AUTO_QT_ENV)
|
2012-08-13 21:47:32 +04:00
|
|
|
get_filename_component(Qt_BIN_DIR "${QT_QMAKE_EXECUTABLE}" PATH)
|
|
|
|
if(EXISTS "${Qt_BIN_DIR}/QtCore4.dll")
|
2009-02-24 17:00:42 +03:00
|
|
|
# Tell the macro to set the path before running cmake-gui.
|
2012-08-13 21:47:32 +04:00
|
|
|
string(REPLACE ";" "\\;" _PATH "PATH=${Qt_BIN_DIR};%PATH%")
|
|
|
|
set(cmake-gui-PATH COMMAND set "${_PATH}")
|
2012-08-13 21:50:14 +04:00
|
|
|
endif()
|
2012-08-15 19:59:36 +04:00
|
|
|
endif()
|
2009-02-24 17:00:42 +03:00
|
|
|
|
2007-06-15 16:53:33 +04:00
|
|
|
# add the docs for the executables
|
|
|
|
ADD_DOCS(ctest ${CMake_SOURCE_DIR}/Utilities/Doxygen/authors.txt)
|
|
|
|
ADD_DOCS(cpack ${CMake_SOURCE_DIR}/Utilities/Doxygen/authors.txt)
|
|
|
|
ADD_DOCS(ccmake ${CMake_SOURCE_DIR}/Utilities/Doxygen/authors.txt)
|
|
|
|
ADD_DOCS(CMakeSetup ${CMake_SOURCE_DIR}/Utilities/Doxygen/doxyfile.in)
|
2009-02-14 05:51:46 +03:00
|
|
|
ADD_DOCS(cmake-gui ${CMake_SOURCE_DIR}/Utilities/Doxygen/doxyfile.in)
|
2007-06-15 16:53:33 +04:00
|
|
|
|
2007-06-28 23:04:28 +04:00
|
|
|
# add the documentation for cmake itself
|
|
|
|
|
2012-08-13 21:47:32 +04:00
|
|
|
get_target_property(CMD cmake LOCATION)
|
|
|
|
add_custom_command(
|
2007-07-02 19:05:43 +04:00
|
|
|
OUTPUT ${CMake_BINARY_DIR}/Docs/cmake.txt
|
2012-08-13 21:42:58 +04:00
|
|
|
COMMAND ${CMD}
|
2007-07-02 19:05:43 +04:00
|
|
|
ARGS --copyright ${CMake_BINARY_DIR}/Docs/Copyright.txt
|
2007-06-28 23:04:28 +04:00
|
|
|
--help-full ${CMake_BINARY_DIR}/Docs/cmake.txt
|
|
|
|
--help-full ${CMake_BINARY_DIR}/Docs/cmake.html
|
|
|
|
--help-full ${CMake_BINARY_DIR}/Docs/cmake.1
|
2008-05-13 23:43:00 +04:00
|
|
|
--help-full ${CMake_BINARY_DIR}/Docs/cmake.docbook
|
|
|
|
--help-policies ${CMake_BINARY_DIR}/Docs/cmake-policies.txt
|
|
|
|
--help-policies ${CMake_BINARY_DIR}/Docs/cmake-policies.html
|
|
|
|
--help-policies ${CMake_BINARY_DIR}/Docs/cmakepolicies.1
|
2007-06-28 23:04:28 +04:00
|
|
|
--help-properties ${CMake_BINARY_DIR}/Docs/cmake-properties.txt
|
|
|
|
--help-properties ${CMake_BINARY_DIR}/Docs/cmake-properties.html
|
2007-07-13 20:03:13 +04:00
|
|
|
--help-properties ${CMake_BINARY_DIR}/Docs/cmakeprops.1
|
2007-10-24 19:36:47 +04:00
|
|
|
--help-variables ${CMake_BINARY_DIR}/Docs/cmake-variables.txt
|
|
|
|
--help-variables ${CMake_BINARY_DIR}/Docs/cmake-variables.html
|
|
|
|
--help-variables ${CMake_BINARY_DIR}/Docs/cmakevars.1
|
2007-06-28 23:04:28 +04:00
|
|
|
--help-modules ${CMake_BINARY_DIR}/Docs/cmake-modules.txt
|
|
|
|
--help-modules ${CMake_BINARY_DIR}/Docs/cmake-modules.html
|
2007-07-13 20:03:13 +04:00
|
|
|
--help-modules ${CMake_BINARY_DIR}/Docs/cmakemodules.1
|
2007-06-28 23:04:28 +04:00
|
|
|
--help-commands ${CMake_BINARY_DIR}/Docs/cmake-commands.txt
|
|
|
|
--help-commands ${CMake_BINARY_DIR}/Docs/cmake-commands.html
|
2007-07-13 20:03:13 +04:00
|
|
|
--help-commands ${CMake_BINARY_DIR}/Docs/cmakecommands.1
|
2007-06-28 23:04:28 +04:00
|
|
|
--help-compatcommands ${CMake_BINARY_DIR}/Docs/cmake-compatcommands.txt
|
|
|
|
--help-compatcommands ${CMake_BINARY_DIR}/Docs/cmake-compatcommands.html
|
2007-07-13 20:03:13 +04:00
|
|
|
--help-compatcommands ${CMake_BINARY_DIR}/Docs/cmakecompat.1
|
2007-07-06 21:08:20 +04:00
|
|
|
DEPENDS cmake
|
2005-07-15 20:01:20 +04:00
|
|
|
MAIN_DEPENDENCY ${CMake_SOURCE_DIR}/Utilities/Doxygen/authors.txt
|
2003-07-22 00:38:53 +04:00
|
|
|
)
|
2007-06-28 23:04:28 +04:00
|
|
|
|
2012-08-13 21:47:32 +04:00
|
|
|
install_files(${CMAKE_MAN_DIR}/man1 FILES ${MAN_FILES})
|
2012-09-07 14:51:59 +04:00
|
|
|
install_files(${CMAKE_DOC_DIR} FILES
|
|
|
|
${TEXT_FILES}
|
|
|
|
${HTML_FILES}
|
|
|
|
${DOCBOOK_FILES}
|
|
|
|
)
|
2012-08-13 21:47:32 +04:00
|
|
|
install(FILES cmake.m4 DESTINATION share/aclocal)
|
2003-07-24 01:59:37 +04:00
|
|
|
|
2003-07-22 01:14:16 +04:00
|
|
|
# Drive documentation generation.
|
2012-08-13 21:47:32 +04:00
|
|
|
add_custom_target(documentation ALL DEPENDS ${DOC_FILES} ${CMake_BINARY_DIR}/Docs/cmake.txt )
|
2010-03-01 16:47:48 +03:00
|
|
|
|
|
|
|
# Documentation testing.
|
|
|
|
if(BUILD_TESTING)
|
|
|
|
find_package(LibXml2 QUIET)
|
|
|
|
if(NOT DEFINED LIBXML2_XMLLINT_EXECUTABLE)
|
|
|
|
find_program(LIBXML2_XMLLINT_EXECUTABLE xmllint)
|
|
|
|
endif()
|
|
|
|
mark_as_advanced(LIBXML2_XMLLINT_EXECUTABLE)
|
|
|
|
if(LIBXML2_XMLLINT_EXECUTABLE)
|
2010-06-23 15:38:33 +04:00
|
|
|
execute_process(COMMAND ${LIBXML2_XMLLINT_EXECUTABLE} --help
|
|
|
|
OUTPUT_VARIABLE _help ERROR_VARIABLE _err)
|
|
|
|
if("${_help}" MATCHES "--path" AND "${_help}" MATCHES "--nonet")
|
2012-09-06 14:31:47 +04:00
|
|
|
# We provide DTDs in the 'xml' directory so that xmllint can run without
|
|
|
|
# network access. Note that xmllints's --path option accepts a
|
|
|
|
# space-separated list of url-encoded paths.
|
|
|
|
set(_dtd_dir "${CMAKE_CURRENT_SOURCE_DIR}/xml")
|
|
|
|
string(REPLACE " " "%20" _dtd_dir "${_dtd_dir}")
|
|
|
|
string(REPLACE ":" "%3A" _dtd_dir "${_dtd_dir}")
|
2010-06-23 15:38:33 +04:00
|
|
|
add_test(CMake.HTML
|
2012-09-06 14:31:47 +04:00
|
|
|
${LIBXML2_XMLLINT_EXECUTABLE} --valid --noout --nonet
|
|
|
|
--path ${_dtd_dir}/xhtml1
|
2010-06-23 15:38:33 +04:00
|
|
|
${HTML_FILES}
|
|
|
|
)
|
2012-09-07 14:51:59 +04:00
|
|
|
add_test(CMake.DocBook
|
|
|
|
${LIBXML2_XMLLINT_EXECUTABLE} --valid --noout --nonet
|
|
|
|
--path ${_dtd_dir}/docbook-4.5
|
|
|
|
${DOCBOOK_FILES}
|
|
|
|
)
|
2010-06-23 15:38:33 +04:00
|
|
|
endif()
|
2010-03-01 16:47:48 +03:00
|
|
|
endif()
|
|
|
|
endif()
|