2022-05-03 16:57:38 +00:00
|
|
|
# Copyright 2018-2022, Collabora, Ltd.
|
2019-03-18 05:52:32 +00:00
|
|
|
# SPDX-License-Identifier: BSL-1.0
|
|
|
|
|
|
|
|
# check if Doxygen is installed
|
|
|
|
find_package(Doxygen)
|
2021-11-11 23:41:58 +00:00
|
|
|
|
2022-05-03 16:57:38 +00:00
|
|
|
option_with_deps(BUILD_DOC "Build documentation" DEPENDS DOXYGEN_FOUND)
|
|
|
|
option_with_deps(
|
|
|
|
BUILD_DOC_WARN_UNDOCUMENTED "Warn on undocumented entities when building documentation"
|
|
|
|
DEFAULT OFF
|
|
|
|
DEPENDS DOXYGEN_FOUND
|
|
|
|
)
|
|
|
|
option_with_deps(
|
|
|
|
BUILD_DOC_EXTRACT_ALL
|
2022-05-17 22:09:20 +00:00
|
|
|
"Extract all entities for documentation, not only documented ones (conflicts with BUILD_DOC_WARN_UNDOCUMENTED)"
|
2022-05-03 16:57:38 +00:00
|
|
|
DEFAULT OFF
|
|
|
|
DEPENDS DOXYGEN_FOUND "NOT BUILD_DOC_WARN_UNDOCUMENTED"
|
|
|
|
)
|
2021-11-11 23:41:58 +00:00
|
|
|
|
2019-03-18 05:52:32 +00:00
|
|
|
if(BUILD_DOC)
|
2020-04-29 08:12:19 +00:00
|
|
|
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()
|
2019-03-18 05:52:32 +00:00
|
|
|
|
2020-04-29 08:12:19 +00:00
|
|
|
# set input and output files
|
|
|
|
set(DOXYGEN_IN ${CMAKE_CURRENT_SOURCE_DIR}/Doxyfile.in)
|
|
|
|
set(DOXYGEN_OUT ${CMAKE_CURRENT_BINARY_DIR}/Doxyfile)
|
2019-03-18 05:52:32 +00:00
|
|
|
|
2020-04-29 08:12:19 +00:00
|
|
|
set(CURBUILDDIR ${CMAKE_CURRENT_BINARY_DIR})
|
|
|
|
set(SRCDIR ${PROJECT_SOURCE_DIR})
|
|
|
|
set(BUILDDIR ${PROJECT_BINARY_DIR})
|
|
|
|
# request to configure the file
|
|
|
|
configure_file(${DOXYGEN_IN} ${DOXYGEN_OUT} @ONLY)
|
2019-03-18 05:52:32 +00:00
|
|
|
|
2021-11-23 19:37:52 +00:00
|
|
|
# copy the schemas
|
2021-11-11 23:41:58 +00:00
|
|
|
configure_file(
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/example_configs/config_v0.schema.json
|
|
|
|
${CMAKE_CURRENT_BINARY_DIR}/html/config_v0.schema.json @ONLY
|
|
|
|
)
|
|
|
|
configure_file(
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/example_configs/config_v0.schema.json.license
|
|
|
|
${CMAKE_CURRENT_BINARY_DIR}/html/config_v0.schema.json.license @ONLY
|
|
|
|
)
|
2021-11-23 19:37:52 +00:00
|
|
|
configure_file(
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/example_configs/calibration_v2.schema.json
|
|
|
|
${CMAKE_CURRENT_BINARY_DIR}/html/calibration_v2.schema.json @ONLY
|
|
|
|
)
|
|
|
|
configure_file(
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/example_configs/calibration_v2.schema.json.license
|
|
|
|
${CMAKE_CURRENT_BINARY_DIR}/html/calibration_v2.schema.json.license @ONLY
|
|
|
|
)
|
2021-04-23 22:25:07 +00:00
|
|
|
|
2020-04-29 08:12:19 +00:00
|
|
|
# note the option ALL which allows to build the docs together with the application
|
2021-11-11 23:41:58 +00:00
|
|
|
add_custom_target(
|
|
|
|
doc_doxygen ALL
|
2020-04-29 08:12:19 +00:00
|
|
|
COMMAND ${DOXYGEN_EXECUTABLE} ${DOXYGEN_OUT}
|
|
|
|
WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
|
|
|
|
COMMENT "Generating API documentation with Doxygen"
|
|
|
|
VERBATIM
|
|
|
|
)
|
2019-03-18 05:52:32 +00:00
|
|
|
endif()
|