3
# Adds a doxygen target that runs doxygen to generate the html
4
# and optionally the LaTeX API documentation.
5
# The doxygen target is added to the doc target as a dependency.
6
# i.e.: the API documentation is built with:
9
# USAGE: GLOBAL INSTALL
12
# cmake ./ && sudo make install
13
# Add the following to the CMakeLists.txt of your project:
14
# include(UseDoxygen OPTIONAL)
15
# Optionally copy Doxyfile.in in the directory of CMakeLists.txt and edit it.
17
# USAGE: INCLUDE IN PROJECT
19
# set(CMAKE_MODULE_PATH ${CMAKE_CURRENT_SOURCE_DIR})
21
# Add the Doxyfile.in and UseDoxygen.cmake files to the projects source directory.
26
# To configure Doxygen you can edit Doxyfile.in and set some variables in cmake.
27
# Variables you may define are:
28
# DOXYFILE_SOURCE_DIR - Path where the Doxygen input files are.
29
# Defaults to the current source directory.
30
# DOXYFILE_EXTRA_SOURCES - Additional source diretories/files for Doxygen to scan.
31
# The Paths should be in double quotes and separated by space. e.g.:
32
# "${CMAKE_CURRENT_BINARY_DIR}/foo.c" "${CMAKE_CURRENT_BINARY_DIR}/bar/"
34
# DOXYFILE_OUTPUT_DIR - Path where the Doxygen output is stored.
35
# Defaults to "${CMAKE_CURRENT_BINARY_DIR}/doc".
37
# DOXYFILE_LATEX - ON/OFF; Set to "ON" if you want the LaTeX documentation
39
# DOXYFILE_LATEX_DIR - Directory relative to DOXYFILE_OUTPUT_DIR where
40
# the Doxygen LaTeX output is stored. Defaults to "latex".
42
# DOXYFILE_HTML_DIR - Directory relative to DOXYFILE_OUTPUT_DIR where
43
# the Doxygen html output is stored. Defaults to "html".
47
# Copyright (c) 2009, 2010, 2011 Tobias Rautenkranz <tobias@rautenkranz.ch>
49
# Redistribution and use is allowed according to the terms of the New
51
# For details see the accompanying COPYING-CMAKE-SCRIPTS file.
56
"Build Doxygen documentation as part of the default build"
60
macro(usedoxygen_set_default name value type docstring)
61
if(NOT DEFINED "${name}")
62
set("${name}" "${value}" CACHE "${type}" "${docstring}")
69
find_file(DOXYFILE_IN "Doxyfile.in"
70
PATHS ${CMAKE_MODULE_PATH} "${CMAKE_ROOT}/Modules/"
72
DOC "Path to the doxygen configuration template file")
73
set(DOXYFILE "${CMAKE_CURRENT_BINARY_DIR}/Doxyfile")
74
include(FindPackageHandleStandardArgs)
75
find_package_handle_standard_args(DOXYFILE_IN DEFAULT_MSG "DOXYFILE_IN")
78
if(DOXYGEN_FOUND AND DOXYFILE_IN_FOUND)
79
usedoxygen_set_default(DOXYFILE_OUTPUT_DIR "${CMAKE_CURRENT_BINARY_DIR}/doc"
80
PATH "Doxygen output directory")
81
usedoxygen_set_default(DOXYFILE_HTML_DIR "html"
82
STRING "Doxygen HTML output directory")
83
usedoxygen_set_default(DOXYFILE_SOURCE_DIR "${CMAKE_CURRENT_SOURCE_DIR}"
84
PATH "Input files source directory")
85
usedoxygen_set_default(DOXYFILE_EXTRA_SOURCE_DIRS ""
86
STRING "Additional source files/directories separated by space")
87
set(DOXYFILE_SOURCE_DIRS "\"${DOXYFILE_SOURCE_DIR}\" ${DOXYFILE_EXTRA_SOURCES}")
89
usedoxygen_set_default(DOXYFILE_LATEX YES BOOL "Generate LaTeX API documentation" OFF)
90
usedoxygen_set_default(DOXYFILE_LATEX_DIR "latex" STRING "LaTex output directory")
92
mark_as_advanced(DOXYFILE_OUTPUT_DIR DOXYFILE_HTML_DIR DOXYFILE_LATEX_DIR
93
DOXYFILE_SOURCE_DIR DOXYFILE_EXTRA_SOURCE_DIRS DOXYFILE_IN)
96
set_property(DIRECTORY
98
ADDITIONAL_MAKE_CLEAN_FILES
99
"${DOXYFILE_OUTPUT_DIR}/${DOXYFILE_HTML_DIR}")
101
add_custom_target(doxygen
102
COMMAND "${DOXYGEN_EXECUTABLE}"
104
COMMENT "Writing documentation to ${DOXYFILE_OUTPUT_DIR}..."
105
WORKING_DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}")
107
set(DOXYFILE_DOT "NO")
108
if(DOXYGEN_DOT_EXECUTABLE)
109
set(DOXYFILE_DOT "YES")
113
set(DOXYFILE_PDFLATEX "NO")
115
set_property(DIRECTORY APPEND PROPERTY
116
ADDITIONAL_MAKE_CLEAN_FILES
117
"${DOXYFILE_OUTPUT_DIR}/${DOXYFILE_LATEX_DIR}")
119
if(DOXYFILE_LATEX STREQUAL "ON")
120
set(DOXYFILE_GENERATE_LATEX "YES")
122
find_program(DOXYFILE_MAKE make)
123
mark_as_advanced(DOXYFILE_MAKE)
124
if(LATEX_COMPILER AND MAKEINDEX_COMPILER AND DOXYFILE_MAKE)
125
if(PDFLATEX_COMPILER)
126
set(DOXYFILE_PDFLATEX "YES")
129
add_custom_command(TARGET doxygen
131
COMMAND "${DOXYFILE_MAKE}"
132
COMMENT "Running LaTeX for Doxygen documentation in ${DOXYFILE_OUTPUT_DIR}/${DOXYFILE_LATEX_DIR}..."
133
WORKING_DIRECTORY "${DOXYFILE_OUTPUT_DIR}/${DOXYFILE_LATEX_DIR}")
135
set(DOXYGEN_LATEX "NO")
138
set(DOXYFILE_GENERATE_LATEX "NO")
142
configure_file("${DOXYFILE_IN}" "${DOXYFILE}" @ONLY)
148
get_target_property(DOC_TARGET doc TYPE)
150
add_custom_target(doc ${ALL})
153
add_dependencies(doc doxygen)