blob: 02ee72f1c5119f179dae605af3c7682c129400c9 [file] [log] [blame]
Minos Galanakisdff2eae2020-07-21 15:13:52 +01001#-------------------------------------------------------------------------------
Summer Qine6cd5e12021-06-23 14:26:17 +08002# Copyright (c) 2020-2021, Arm Limited. All rights reserved.
Minos Galanakisdff2eae2020-07-21 15:13:52 +01003#
4# SPDX-License-Identifier: BSD-3-Clause
5#
6#-------------------------------------------------------------------------------
7
Raef Coles69817322020-10-19 14:14:14 +01008cmake_minimum_required(VERSION 3.15)
Minos Galanakisdff2eae2020-07-21 15:13:52 +01009
10add_custom_target(docs)
11
Anton Komlev6be16032021-10-13 21:51:23 +010012list(APPEND CMAKE_MODULE_PATH ${CMAKE_SOURCE_DIR}/cmake)
Anton Komlevceafd012021-10-11 23:21:11 +010013
Minos Galanakisdff2eae2020-07-21 15:13:52 +010014find_package(Python3)
15find_package(Sphinx)
Anton Komlevceafd012021-10-11 23:21:11 +010016
17# suppress warnings on mismatched names in PythonModules
18set(FPHSA_NAME_MISMATCHED True)
Anton Komlev27a52c22021-10-16 02:04:09 +010019find_package(PythonModules COMPONENTS m2r2 sphinx-rtd-theme sphinxcontrib.plantuml)
Minos Galanakisdff2eae2020-07-21 15:13:52 +010020find_package(PlantUML)
21find_package(Doxygen 1.8.0)
22find_package(LATEX COMPONENTS PDFLATEX)
23
24################################## ENV #########################################
25
Anton Komlev2d2a6fc2022-02-20 15:47:53 +000026include(../cmake/version.cmake)
Anton Komlevceafd012021-10-11 23:21:11 +010027
28project("Trusted Firmware M. Documentation" VERSION ${TFM_VERSION} LANGUAGES)
29
Anton Komlevb813dbc2022-04-01 21:12:16 +010030set(SPHINXCFG_SOURCE_PATH ${CMAKE_CURRENT_SOURCE_DIR})
31set(SPHINXCFG_CONFIG_PATH ${CMAKE_CURRENT_SOURCE_DIR})
Minos Galanakisdff2eae2020-07-21 15:13:52 +010032set(SPHINXCFG_OUTPUT_PATH ${CMAKE_CURRENT_BINARY_DIR}/user_guide)
Anton Komlevb813dbc2022-04-01 21:12:16 +010033
Minos Galanakisdff2eae2020-07-21 15:13:52 +010034set(DOXYCFG_OUTPUT_PATH ${CMAKE_CURRENT_BINARY_DIR}/reference_manual)
35set(DOXYCFG_DOXYGEN_CFG_DIR ${CMAKE_SOURCE_DIR}/doxygen)
36
37# Enable to request the interface to build the doxygen documentation as well
38set(DOXYCFG_DOXYGEN_BUILD False)
39
40################################## SPHINX ######################################
Minos Galanakisdff2eae2020-07-21 15:13:52 +010041
Anton Komlev27a52c22021-10-16 02:04:09 +010042if (SPHINX_FOUND AND PLANTUML_FOUND AND PY_M2R2_FOUND AND PY_SPHINX-RTD-THEME_FOUND AND PY_SPHINXCONTRIB.PLANTUML)
Minos Galanakisdff2eae2020-07-21 15:13:52 +010043
Anton Komlevb813dbc2022-04-01 21:12:16 +010044 file(GLOB_RECURSE SPHINXCFG_DOC_FILES ${SPHINXCFG_SOURCE_PATH}/*.rst)
Minos Galanakisdff2eae2020-07-21 15:13:52 +010045
Anton Komlevb813dbc2022-04-01 21:12:16 +010046 add_custom_target(tfm_docs_userguide_html ALL
47 COMMAND "${SPHINX_EXECUTABLE}" -W -b html -j auto -c ${SPHINXCFG_CONFIG_PATH} ${SPHINXCFG_SOURCE_PATH} "${SPHINXCFG_OUTPUT_PATH}/html"
48 WORKING_DIRECTORY ${SPHINXCFG_SOURCE_PATH}
Minos Galanakisdff2eae2020-07-21 15:13:52 +010049 DEPENDS ${SPHINXCFG_DOC_FILES}
50 )
Anton Komlevb813dbc2022-04-01 21:12:16 +010051
Minos Galanakisdff2eae2020-07-21 15:13:52 +010052 add_dependencies(docs tfm_docs_userguide_html)
53
54 if (LATEX_PDFLATEX_FOUND)
55 add_custom_command(OUTPUT "${SPHINXCFG_OUTPUT_PATH}/latex/TF-M.tex"
56 OUTPUT "${SPHINXCFG_OUTPUT_PATH}/latex/"
57 COMMAND "${SPHINX_EXECUTABLE}" -b latex "${SPHINX_TMP_DOC_DIR}" "${SPHINXCFG_OUTPUT_PATH}/latex"
58 WORKING_DIRECTORY "${CMAKE_SOURCE_DIR}"
59 DEPENDS tfm_docs_sphinx_cfg
60 DEPENDS ${SPHINXCFG_DOC_FILES}
61 )
62 add_custom_command(OUTPUT "${SPHINXCFG_OUTPUT_PATH}/latex/TF-M.pdf"
63 COMMAND ${PDFLATEX_COMPILER} TF-M.tex
64 COMMAND ${CMAKE_COMMAND} -E copy TF-M.tex ${SPHINXCFG_OUTPUT_PATH}/tf-m_user_guide.pdf
65 WORKING_DIRECTORY ${SPHINXCFG_OUTPUT_PATH}/latex/
66 DEPENDS "${SPHINXCFG_OUTPUT_PATH}/latex/TF-M.tex"
67 )
68 add_custom_target(tfm_docs_userguide_pdf
69 DEPENDS "${SPHINXCFG_OUTPUT_PATH}/latex/TF-M.pdf"
70 )
71 add_dependencies(docs tfm_docs_userguide_pdf)
72 endif()
73endif()
74
75################################## DOXYGEN #####################################
76
Minos Galanakisdff2eae2020-07-21 15:13:52 +010077if (DOXYGEN_FOUND AND DOXYGEN_DOT_FOUND AND PLANTUML_FOUND)
78
Anton Komlevb813dbc2022-04-01 21:12:16 +010079 configure_file(${CMAKE_SOURCE_DIR}/doxygen/Doxyfile.in ${CMAKE_CURRENT_BINARY_DIR}/Doxyfile @ONLY)
Minos Galanakisdff2eae2020-07-21 15:13:52 +010080 file(GLOB_RECURSE DOXYCFG_DOC_FILES ${CMAKE_SOURCE_DIR}/*.c ${CMAKE_SOURCE_DIR}/*.h)
81
82 add_custom_command(OUTPUT ${DOXYCFG_OUTPUT_PATH}/html
83 OUTPUT ${DOXYCFG_OUTPUT_PATH}/latex
84 OUTPUT ${DOXYCFG_OUTPUT_PATH}/latex/refman.pdf
85 COMMAND ${DOXYGEN_EXECUTABLE} ${CMAKE_CURRENT_BINARY_DIR}/Doxyfile
86 WORKING_DIRECTORY ${CMAKE_SOURCE_DIR}
87 DEPENDS ${DOXYCFG_DOC_FILES}
88 )
Anton Komlevceafd012021-10-11 23:21:11 +010089 add_custom_target(tfm_docs_refman_html ALL
Minos Galanakisdff2eae2020-07-21 15:13:52 +010090 WORKING_DIRECTORY ${CMAKE_SOURCE_DIR}
91 DEPENDS ${DOXYCFG_OUTPUT_PATH}/html
92 )
93 add_dependencies(docs tfm_docs_refman_html)
94
95 if (LATEX_PDFLATEX_FOUND)
96 add_custom_command(OUTPUT "${DOXYCFG_OUTPUT_PATH}/latex/refman.pdf"
97 COMMAND "${PDFLATEX_COMPILER} refman.tex"
98 COMMAND ${CMAKE_COMMAND} -E copy refman.tex ${DOXYCFG_OUTPUT_PATH}/tf-m_reference_manual.pdf
99 WORKING_DIRECTORY ${DOXYCFG_OUTPUT_PATH}/latex/
100 DEPENDS "${DOXYCFG_OUTPUT_PATH}/latex/refman.tex"
101 )
102 add_custom_target(tfm_docs_refman_pdf
103 DEPENDS ${DOXYCFG_OUTPUT_PATH}/latex/refman.pdf
104 DEPENDS tfm_docs_refman_html
105 )
106 add_dependencies(docs tfm_docs_refman_pdf)
107 endif()
108endif()