Gyorgy Szing | 74dae3c | 2018-09-27 17:00:46 +0200 | [diff] [blame] | 1 | #------------------------------------------------------------------------------- |
Minos Galanakis | 0768982 | 2020-03-10 15:37:20 +0000 | [diff] [blame] | 2 | # Copyright (c) 2019-2020, Arm Limited. All rights reserved. |
Gyorgy Szing | 74dae3c | 2018-09-27 17:00:46 +0200 | [diff] [blame] | 3 | # |
| 4 | # SPDX-License-Identifier: BSD-3-Clause |
| 5 | # |
| 6 | #------------------------------------------------------------------------------- |
| 7 | |
| 8 | #This file adds build and install targets to build the Sphinx documentation |
| 9 | #for TF-M. This currently means the "User Guide". Further documentation |
| 10 | #builds may be added in the future. |
| 11 | |
| 12 | Include(CMakeParseArguments) |
| 13 | |
| 14 | #This function will find the location of tools needed to build the |
| 15 | #documentation. These are: |
| 16 | # - Mandatory: |
| 17 | # - Sphinx 1.9.0 or higher |
| 18 | # - PlantUML and it's dependencies |
| 19 | # - Optional |
| 20 | # - LateX/PDFLateX |
| 21 | # |
| 22 | #Inputs: |
| 23 | # none (some global variables might be used by FindXXX modules used. For |
| 24 | # details please check the modules used.) |
| 25 | #Outputs: |
| 26 | # SPHINX_NODOC - will be defined and set to true is any mandatory tool is |
| 27 | # missing. |
Gyorgy Szing | d9c57fb | 2019-09-02 17:08:18 +0200 | [diff] [blame] | 28 | # LATEX_PDFLATEX_FOUND - true if pdflatex executable found |
| 29 | # SPHINX_EXECUTABLE - path to sphinx-build |
| 30 | # PLANTUML_JAR_PATH - path to PlantUML |
Gyorgy Szing | 74dae3c | 2018-09-27 17:00:46 +0200 | [diff] [blame] | 31 | |
| 32 | #Examples |
| 33 | # SphinxFindTools() |
| 34 | # |
| 35 | function(SphinxFindTools) |
Gyorgy Szing | db9783c | 2019-04-17 21:08:48 +0200 | [diff] [blame] | 36 | #Find Sphinx |
Gyorgy Szing | 74dae3c | 2018-09-27 17:00:46 +0200 | [diff] [blame] | 37 | find_package(Sphinx) |
| 38 | |
Gyorgy Szing | db9783c | 2019-04-17 21:08:48 +0200 | [diff] [blame] | 39 | #Find additional needed Sphinx dependencies. |
| 40 | find_package(PythonModules COMPONENTS m2r sphinx-rtd-theme sphinxcontrib.plantuml) |
Gyorgy Szing | 74dae3c | 2018-09-27 17:00:46 +0200 | [diff] [blame] | 41 | |
| 42 | #Find plantUML |
| 43 | find_package(PlantUML) |
| 44 | |
| 45 | #Find tools needed for PDF generation. |
| 46 | find_package(LATEX COMPONENTS PDFLATEX) |
Gyorgy Szing | d9c57fb | 2019-09-02 17:08:18 +0200 | [diff] [blame] | 47 | set (LATEX_PDFLATEX_FOUND "${LATEX_PDFLATEX_FOUND}" PARENT_SCOPE) |
Gyorgy Szing | 74dae3c | 2018-09-27 17:00:46 +0200 | [diff] [blame] | 48 | |
| 49 | if (SPHINX_FOUND AND PLANTUML_FOUND AND PY_M2R_FOUND |
Gyorgy Szing | db9783c | 2019-04-17 21:08:48 +0200 | [diff] [blame] | 50 | AND PY_SPHINX-RTD-THEME_FOUND AND PY_SPHINXCONTRIB.PLANTUML) |
Gyorgy Szing | 74dae3c | 2018-09-27 17:00:46 +0200 | [diff] [blame] | 51 | #Export executable locations to global scope. |
| 52 | set(SPHINX_EXECUTABLE "${SPHINX_EXECUTABLE}" PARENT_SCOPE) |
| 53 | set(PLANTUML_JAR_PATH "${PLANTUML_JAR_PATH}" PARENT_SCOPE) |
Gyorgy Szing | db9783c | 2019-04-17 21:08:48 +0200 | [diff] [blame] | 54 | set(Java_JAVA_EXECUTABLE "${Java_JAVA_EXECUTABLE}" PARENT_SCOPE) |
Gyorgy Szing | 74dae3c | 2018-09-27 17:00:46 +0200 | [diff] [blame] | 55 | set(SPHINX_NODOC False PARENT_SCOPE) |
| 56 | else() |
| 57 | message(WARNING "Some tools are missing for Sphinx document generation. Document generation target is not created.") |
| 58 | set(SPHINX_NODOC True PARENT_SCOPE) |
| 59 | endif() |
| 60 | endfunction() |
| 61 | |
| 62 | #Find the needed tools. |
| 63 | SphinxFindTools() |
| 64 | |
| 65 | #If mandatory tools are missing, skip creating document generation targets. |
| 66 | #This means missing documentation tools is not a critical error, and building |
| 67 | #TF-M is still possible. |
| 68 | if (NOT SPHINX_NODOC) |
| 69 | #The Sphinx configuration file needs some project specific configuration. |
| 70 | #Variables with SPHINXCFG_ prefix are setting values related to that. |
| 71 | #This is where Sphinx output will be written |
| 72 | set(SPHINXCFG_OUTPUT_PATH "${CMAKE_CURRENT_BINARY_DIR}/doc_sphinx") |
| 73 | |
| 74 | set(SPHINX_TMP_DOC_DIR "${CMAKE_CURRENT_BINARY_DIR}/doc_sphinx_in") |
Minos Galanakis | d19a19f | 2020-06-03 15:38:03 +0100 | [diff] [blame^] | 75 | set(SPHINXCFG_CONFIGURED_FILE "${TFM_ROOT_DIR}/build_docs/conf.py") |
Gyorgy Szing | db9783c | 2019-04-17 21:08:48 +0200 | [diff] [blame] | 76 | set(SPHINXCFG_TEMPLATE_FILE "${TFM_ROOT_DIR}/docs/conf.py.in") |
Minos Galanakis | d19a19f | 2020-06-03 15:38:03 +0100 | [diff] [blame^] | 77 | set(SPHINXCFG_ENVIRONMENT_FILE "${TFM_ROOT_DIR}/docs/tfm_env.py.in") |
| 78 | set(_PDF_FILE "${SPHINXCFG_OUTPUT_PATH}/latex/TF-M.pdf") |
Gyorgy Szing | 74dae3c | 2018-09-27 17:00:46 +0200 | [diff] [blame] | 79 | |
Minos Galanakis | d19a19f | 2020-06-03 15:38:03 +0100 | [diff] [blame^] | 80 | # Set the build-tool to copy over the files to ${SPHINX_TMP_DOC_DIR~ |
| 81 | set(SPHINXCFG_COPY_FILES True) |
| 82 | # Set the config to render the conf.py. If needed to build it by cmake |
| 83 | # set it to False |
| 84 | set(SPHINXCFG_RENDER_CONF True) |
| 85 | |
| 86 | # TODO Reference example on how a doxygen build can be requested. |
| 87 | # Currently the logic of BuildDoxygenDoc.cmake is still used for |
| 88 | # compatibility purposes. |
| 89 | set(DOXYCFG_DOXYGEN_BUILD False) |
| 90 | if (SPHINXCFG_RENDER_CONF) |
| 91 | find_package(Doxygen 1.8.0) |
| 92 | set(DOXYCFG_DOXYGEN_CFG_DIR ${TFM_ROOT_DIR}/doxygen) |
| 93 | set(DOXYCFG_OUTPUT_PATH ${SPHINXCFG_OUTPUT_PATH}/user_manual) |
| 94 | set(DOXYCFG_ECLIPSE_DOCID "org.arm.tf-m-refman") |
| 95 | file(MAKE_DIRECTORY ${SPHINXCFG_OUTPUT_PATH}/user_manual) |
| 96 | endif() |
Gyorgy Szing | 74dae3c | 2018-09-27 17:00:46 +0200 | [diff] [blame] | 97 | |
| 98 | #Version ID of TF-M. |
| 99 | #TODO: this shall not be hard-coded here. We need a process to define the |
| 100 | # version number of the document (and TF-M). |
Mate Toth-Pal | 955235a | 2020-06-15 13:48:34 +0200 | [diff] [blame] | 101 | set(SPHINXCFG_TFM_VERSION "v1.1") |
| 102 | set(SPHINXCFG_TFM_VERSION_FULL "Version 1.1") |
Gyorgy Szing | 74dae3c | 2018-09-27 17:00:46 +0200 | [diff] [blame] | 103 | |
Gyorgy Szing | d9c57fb | 2019-09-02 17:08:18 +0200 | [diff] [blame] | 104 | #This command does not generates the specified output file and thus it will |
| 105 | #always be run. Any other command or target depending on the "run-allways" |
| 106 | #output will be always executed too. |
Gyorgy Szing | 5c87323 | 2019-05-10 23:28:14 +0200 | [diff] [blame] | 107 | add_custom_command(OUTPUT run-allways |
| 108 | COMMAND "${CMAKE_COMMAND}" -E echo) |
| 109 | |
Minos Galanakis | d19a19f | 2020-06-03 15:38:03 +0100 | [diff] [blame^] | 110 | file(REMOVE_RECURSE ${SPHINX_TMP_DOC_DIR}) |
| 111 | file(MAKE_DIRECTORY ${SPHINX_TMP_DOC_DIR}) |
| 112 | |
| 113 | #Call configure file to fill out the message template. |
| 114 | configure_file("${SPHINXCFG_ENVIRONMENT_FILE}" "${SPHINX_TMP_DOC_DIR}/tfm_env.py" @ONLY) |
| 115 | |
| 116 | file(COPY "${SPHINXCFG_CONFIGURED_FILE}" DESTINATION ${SPHINX_TMP_DOC_DIR}) |
Gyorgy Szing | 74dae3c | 2018-09-27 17:00:46 +0200 | [diff] [blame] | 117 | |
Gyorgy Szing | db9783c | 2019-04-17 21:08:48 +0200 | [diff] [blame] | 118 | add_custom_target(create_sphinx_input |
| 119 | SOURCES "${SPHINX_TMP_DOC_DIR}" |
| 120 | ) |
| 121 | |
Gyorgy Szing | 74dae3c | 2018-09-27 17:00:46 +0200 | [diff] [blame] | 122 | add_custom_command(OUTPUT "${SPHINXCFG_OUTPUT_PATH}/html" |
Minos Galanakis | d19a19f | 2020-06-03 15:38:03 +0100 | [diff] [blame^] | 123 | COMMAND "${SPHINX_EXECUTABLE}" -b html "${SPHINX_TMP_DOC_DIR}" "${SPHINXCFG_OUTPUT_PATH}/html" |
Gyorgy Szing | 74dae3c | 2018-09-27 17:00:46 +0200 | [diff] [blame] | 124 | WORKING_DIRECTORY "${TFM_ROOT_DIR}" |
Gyorgy Szing | 5c87323 | 2019-05-10 23:28:14 +0200 | [diff] [blame] | 125 | DEPENDS create_sphinx_input run-allways |
Gyorgy Szing | 74dae3c | 2018-09-27 17:00:46 +0200 | [diff] [blame] | 126 | COMMENT "Running Sphinx to generate user guide (HTML)." |
| 127 | VERBATIM |
| 128 | ) |
| 129 | |
| 130 | #Create build target to generate HTML documentation. |
| 131 | add_custom_target(doc_userguide |
| 132 | COMMENT "Generating User Guide with Sphinx..." |
| 133 | #Copy document files from the top level dir to docs |
| 134 | SOURCES "${SPHINXCFG_OUTPUT_PATH}/html" |
| 135 | ) |
| 136 | |
| 137 | #Add the HTML documentation to install content |
| 138 | install(DIRECTORY ${SPHINXCFG_OUTPUT_PATH}/html DESTINATION doc/user_guide |
| 139 | EXCLUDE_FROM_ALL |
| 140 | COMPONENT user_guide |
| 141 | PATTERN .buildinfo EXCLUDE |
| 142 | ) |
| 143 | |
Minos Galanakis | d19a19f | 2020-06-03 15:38:03 +0100 | [diff] [blame^] | 144 | if (DOXYCFG_DOXYGEN_BUILD) |
| 145 | #Add the HTML documentation to install content |
| 146 | install(DIRECTORY ${SPHINXCFG_OUTPUT_PATH}/user_manual DESTINATION doc |
| 147 | EXCLUDE_FROM_ALL |
| 148 | COMPONENT user_guide |
| 149 | PATTERN .buildinfo EXCLUDE |
| 150 | ) |
| 151 | endif() |
| 152 | |
Gyorgy Szing | 74dae3c | 2018-09-27 17:00:46 +0200 | [diff] [blame] | 153 | #If PDF documentation is being made. |
Gyorgy Szing | d9c57fb | 2019-09-02 17:08:18 +0200 | [diff] [blame] | 154 | if (LATEX_PDFLATEX_FOUND) |
| 155 | if (NOT CMAKE_GENERATOR MATCHES "Makefiles") |
| 156 | message(WARNING "Generator is not make based. PDF document generation target is not created.") |
| 157 | else() |
| 158 | #This file shall not be included before cmake did finish finding the make tool and thus |
| 159 | #setting CMAKE_MAKE_PROGRAM. Currently the search is triggered by the project() command. |
| 160 | if(NOT CMAKE_MAKE_PROGRAM) |
| 161 | message(FATAL_ERROR "CMAKE_MAKE_PROGRAM is not set. This file must be included after the project command is run.") |
| 162 | endif() |
Gyorgy Szing | 74dae3c | 2018-09-27 17:00:46 +0200 | [diff] [blame] | 163 | |
Gyorgy Szing | d9c57fb | 2019-09-02 17:08:18 +0200 | [diff] [blame] | 164 | add_custom_command(OUTPUT "${SPHINXCFG_OUTPUT_PATH}/latex" |
Minos Galanakis | d19a19f | 2020-06-03 15:38:03 +0100 | [diff] [blame^] | 165 | COMMAND "${SPHINX_EXECUTABLE}" -b latex "${SPHINX_TMP_DOC_DIR}" "${SPHINXCFG_OUTPUT_PATH}/latex" |
Gyorgy Szing | d9c57fb | 2019-09-02 17:08:18 +0200 | [diff] [blame] | 166 | WORKING_DIRECTORY "${TFM_ROOT_DIR}" |
| 167 | DEPENDS create_sphinx_input |
| 168 | COMMENT "Running Sphinx to generate user guide (LaTeX)." |
| 169 | VERBATIM |
| 170 | ) |
Gyorgy Szing | 74dae3c | 2018-09-27 17:00:46 +0200 | [diff] [blame] | 171 | |
Gyorgy Szing | d9c57fb | 2019-09-02 17:08:18 +0200 | [diff] [blame] | 172 | add_custom_command(OUTPUT "${_PDF_FILE}" |
| 173 | COMMAND "${CMAKE_MAKE_PROGRAM}" all-pdf |
| 174 | WORKING_DIRECTORY ${SPHINXCFG_OUTPUT_PATH}/latex |
| 175 | DEPENDS "${SPHINXCFG_OUTPUT_PATH}/latex" |
| 176 | COMMENT "Generating PDF version of User Guide..." |
| 177 | VERBATIM |
| 178 | ) |
Gyorgy Szing | 74dae3c | 2018-09-27 17:00:46 +0200 | [diff] [blame] | 179 | |
Gyorgy Szing | d9c57fb | 2019-09-02 17:08:18 +0200 | [diff] [blame] | 180 | #We do not use the add_custom_command trick here to get proper clean |
| 181 | #command since the clean rules "added" above will remove the entire |
| 182 | #doc directory, and thus clean the PDF output too. |
| 183 | add_custom_target(doc_userguide_pdf |
| 184 | COMMENT "Generating PDF version of TF-M User Guide..." |
| 185 | SOURCES "${_PDF_FILE}" |
| 186 | VERBATIM) |
| 187 | |
| 188 | #Add the pdf documentation to install content |
| 189 | install(FILES "${_PDF_FILE}" DESTINATION "doc/user_guide" |
| 190 | RENAME "tf-m_user_guide.pdf" |
| 191 | COMPONENT user_guide |
| 192 | EXCLUDE_FROM_ALL) |
| 193 | endif() |
Gyorgy Szing | 74dae3c | 2018-09-27 17:00:46 +0200 | [diff] [blame] | 194 | else() |
| 195 | message(WARNING "PDF generation tools are missing. PDF document generation target is not created.") |
| 196 | endif() |
| 197 | |
| 198 | #Generate build target which installs the documentation. |
| 199 | if (TARGET doc_userguide_pdf) |
| 200 | add_custom_target(install_userguide |
| 201 | DEPENDS doc_userguide doc_userguide_pdf |
| 202 | COMMAND "${CMAKE_COMMAND}" -DCMAKE_INSTALL_COMPONENT=user_guide |
| 203 | -P "${CMAKE_BINARY_DIR}/cmake_install.cmake") |
| 204 | else() |
| 205 | add_custom_target(install_userguide |
| 206 | DEPENDS doc_userguide |
| 207 | COMMAND "${CMAKE_COMMAND}" -DCMAKE_INSTALL_COMPONENT=user_guide |
| 208 | -P "${CMAKE_BINARY_DIR}/cmake_install.cmake") |
| 209 | endif() |
| 210 | |
Gyorgy Szing | 74dae3c | 2018-09-27 17:00:46 +0200 | [diff] [blame] | 211 | endif() |