2019-03-18 05:52:32 +00:00
# Copyright 2018-2019, Collabora, Ltd.
# SPDX-License-Identifier: BSL-1.0
# check if Doxygen is installed
find_package ( Doxygen )
cmake_dependent_option ( BUILD_DOC "Build documentation" ON "DOXYGEN_FOUND" OFF )
cmake_dependent_option ( BUILD_DOC_WARN_UNDOCUMENTED "Warn on undocumented entities when building documentation" OFF "DOXYGEN_FOUND" OFF )
cmake_dependent_option ( BUILD_DOC_EXTRACT_ALL "Extract all entities for documentation, not just documented ones (conflicts with BUILD_DOCS_WARN_UNDOCUMENTED)" ON "DOXYGEN_FOUND; NOT BUILD_DOCS_WARN_UNDOCUMENTED" OFF )
if ( BUILD_DOC )
if ( BUILD_DOC_WARN_UNDOCUMENTED )
set ( DOXYGEN_WARN_UNDOCUMENTED YES )
else ( )
set ( DOXYGEN_WARN_UNDOCUMENTED NO )
endif ( )
if ( BUILD_DOC_EXTRACT_ALL )
set ( DOXYGEN_EXTRACT_ALL YES )
else ( )
set ( DOXYGEN_EXTRACT_ALL NO )
endif ( )
# set input and output files
2020-03-02 20:14:11 +00:00
set ( DOXYGEN_IN ${ CMAKE_CURRENT_SOURCE_DIR } /Doxyfile.cmake_in )
2019-03-18 05:52:32 +00:00
set ( DOXYGEN_OUT ${ CMAKE_CURRENT_BINARY_DIR } /Doxyfile )
# request to configure the file
configure_file ( ${ DOXYGEN_IN } ${ DOXYGEN_OUT } @ONLY )
# note the option ALL which allows to build the docs together with the application
add_custom_target ( doc_doxygen ALL
C O M M A N D $ { D O X Y G E N _ E X E C U T A B L E } $ { D O X Y G E N _ O U T }
W O R K I N G _ D I R E C T O R Y $ { C M A K E _ C U R R E N T _ B I N A R Y _ D I R }
C O M M E N T " G e n e r a t i n g A P I d o c u m e n t a t i o n w i t h D o x y g e n "
V E R B A T I M
)
endif ( )