blob: 4c34e20e679d321f8668924dcead7177f5a1df70 [file] [log] [blame]
Anas Nashif3ae52622019-04-06 09:08:09 -04001# SPDX-License-Identifier: Apache-2.0
2
Anas Nashif5060ca62018-12-11 10:33:23 -05003cmake_minimum_required(VERSION 3.13.1)
Sebastian Bøe5748fe12019-01-04 09:13:07 +01004project(Zephyr-Kernel-Doc LANGUAGES)
Carles Cufiae699342018-07-09 14:12:17 +02005
Torsten Rasmussend7862cf2020-02-12 15:42:09 +01006set(NO_BOILERPLATE TRUE)
Marc Herbert3a045362020-05-28 21:54:50 -07007find_package(Zephyr REQUIRED HINTS $ENV{ZEPHYR_BASE} ..)
Torsten Rasmussend7862cf2020-02-12 15:42:09 +01008
Carles Cufi1aa4d8d2019-03-28 17:49:25 +01009# Find west to (optionally) process modules for Kconfig
10find_program(
11 WEST
12 west
13 )
14if(${WEST} STREQUAL WEST-NOTFOUND)
15 unset(WEST)
16endif()
17
Torsten Rasmussend7862cf2020-02-12 15:42:09 +010018file(TO_CMAKE_PATH "${ZEPHYR_BASE}" ZEPHYR_BASE)
Carles Cufiae699342018-07-09 14:12:17 +020019
20message(STATUS "Zephyr base: ${ZEPHYR_BASE}")
Marti Bolivar2b3d9df2019-07-22 11:00:59 -060021if(DEFINED WEST)
Martí Bolívar17144482020-02-11 08:27:14 -080022 execute_process(COMMAND west --version
23 OUTPUT_STRIP_TRAILING_WHITESPACE OUTPUT_VARIABLE WEST_VERSION)
24 message(STATUS "West: ${WEST} (west --version: \"${WEST_VERSION}\")")
Marti Bolivar2b3d9df2019-07-22 11:00:59 -060025else()
26 message(STATUS "West: not found")
27endif()
Carles Cufiae699342018-07-09 14:12:17 +020028
Torsten Rasmussen92507402020-05-04 08:33:59 +020029include(${ZEPHYR_BASE}/cmake/python.cmake)
Carles Cufiae699342018-07-09 14:12:17 +020030set(DOXYGEN_SKIP_DOT True)
31find_package(Doxygen REQUIRED)
Carles Cufi0698dba2018-10-02 10:30:39 +020032find_package(LATEX)
Carles Cufiae699342018-07-09 14:12:17 +020033
34find_program(
35 SPHINXBUILD
Marc Herberta49f9eb2019-02-04 15:24:01 -080036 NAMES sphinx-build-3 sphinx-build
Carles Cufiae699342018-07-09 14:12:17 +020037 )
38if(${SPHINXBUILD} STREQUAL SPHINXBUILD-NOTFOUND)
39 message(FATAL_ERROR "The 'sphinx-build' command was not found. Make sure you have Sphinx installed.")
40endif()
41
Carles Cufif5f1b222019-05-23 16:37:58 +020042# Include version info
43include(${ZEPHYR_BASE}/cmake/version.cmake)
44# Process modules
Torsten Rasmussen5f7cc8d2020-07-06 12:53:39 +020045set(KCONFIG_BINARY_DIR ${CMAKE_BINARY_DIR}/Kconfig)
46file(MAKE_DIRECTORY ${KCONFIG_BINARY_DIR})
Carles Cufif5f1b222019-05-23 16:37:58 +020047include(${ZEPHYR_BASE}/cmake/zephyr_module.cmake)
48
Daniel Leung9945e7f2018-08-23 11:11:11 -070049# Note that this won't force fatal error if latexmk is not found.
50# Not having LaTeX tools should not prevent people from generating HTML docs.
51find_program(
52 LATEXMK
53 latexmk
54 )
55if(${LATEXMK} STREQUAL LATEXMK-NOTFOUND)
56 message(WARNING "The 'latexmk' command was not found. Targets to build PDF will not be available.")
57endif()
58
Carles Cufiae699342018-07-09 14:12:17 +020059if(NOT DEFINED SPHINXOPTS)
60 set(SPHINXOPTS -q)
Carles Cufid505ca72018-07-13 12:37:13 +020061else()
62 separate_arguments(SPHINXOPTS)
Carles Cufiae699342018-07-09 14:12:17 +020063endif()
64
Carles Cufi896a6962018-08-16 13:45:59 +020065if(NOT DEFINED SPHINX_OUTPUT_DIR)
Daniel Leung9945e7f2018-08-23 11:11:11 -070066 set(SPHINX_OUTPUT_DIR_HTML ${CMAKE_CURRENT_BINARY_DIR}/html)
67 set(SPHINX_OUTPUT_DIR_LATEX ${CMAKE_CURRENT_BINARY_DIR}/latex)
68 set(SPHINX_OUTPUT_DIR_PDF ${CMAKE_CURRENT_BINARY_DIR}/pdf)
69else()
Marti Bolivar2952bf82018-10-09 13:28:41 -060070 # SPHINX_OUTPUT_DIR is used to specify exactly where HTML (or other
71 # outputs) are placed, so no /html, /latex, /pdf suffixes are needed.
Daniel Leung9945e7f2018-08-23 11:11:11 -070072 set(SPHINX_OUTPUT_DIR_HTML ${SPHINX_OUTPUT_DIR})
73 set(SPHINX_OUTPUT_DIR_LATEX ${SPHINX_OUTPUT_DIR})
74 set(SPHINX_OUTPUT_DIR_PDF ${SPHINX_OUTPUT_DIR})
Carles Cufi896a6962018-08-16 13:45:59 +020075endif()
76
Carles Cufiae699342018-07-09 14:12:17 +020077if(NOT DEFINED DOC_TAG)
78 set(DOC_TAG development)
79endif()
80
81# Internal variables.
Carles Cufi2af9a9e2018-07-13 15:32:36 +020082set(ALLSPHINXOPTS -d ${CMAKE_CURRENT_BINARY_DIR}/doctrees ${SPHINXOPTS})
Carles Cufi60c55402018-07-15 18:57:01 +020083if("-q" IN_LIST ALLSPHINXOPTS)
84 set(SPHINX_USES_TERMINAL )
85else()
86 set(SPHINX_USES_TERMINAL USES_TERMINAL)
87endif()
88
Carles Cufiae699342018-07-09 14:12:17 +020089# the i18n builder cannot share the environment and doctrees with the others
Carles Cufid505ca72018-07-13 12:37:13 +020090set(I18NSPHINXOPTS ${SPHINXOPTS})
Carles Cufiae699342018-07-09 14:12:17 +020091
Carles Cufie182dbc2018-07-16 19:05:05 +020092set(DOXYFILE_IN ${CMAKE_CURRENT_LIST_DIR}/zephyr.doxyfile.in)
93set(DOXYFILE_OUT ${CMAKE_CURRENT_BINARY_DIR}/zephyr.doxyfile)
Carles Cufi40b63e52019-02-19 13:47:03 +010094set(DOXY_OUT ${CMAKE_CURRENT_BINARY_DIR}/doxygen)
Carles Cufie182dbc2018-07-16 19:05:05 +020095set(RST_OUT ${CMAKE_CURRENT_BINARY_DIR}/rst)
96set(DOC_LOG ${CMAKE_CURRENT_BINARY_DIR}/doc.log)
97set(DOXY_LOG ${CMAKE_CURRENT_BINARY_DIR}/doxy.log)
98set(SPHINX_LOG ${CMAKE_CURRENT_BINARY_DIR}/sphinx.log)
99set(DOC_WARN ${CMAKE_CURRENT_BINARY_DIR}/doc.warnings)
Marti Bolivar0913c292018-10-09 12:42:03 -0600100set(CONTENT_OUTPUTS ${CMAKE_CURRENT_BINARY_DIR}/extracted-content.txt)
Carles Cufiae699342018-07-09 14:12:17 +0200101
Carles Cufie182dbc2018-07-16 19:05:05 +0200102configure_file(${DOXYFILE_IN} ${DOXYFILE_OUT} @ONLY)
Carles Cufiae699342018-07-09 14:12:17 +0200103
Marc Herbertfc644812019-02-15 10:41:25 -0800104# This command is used to copy all documentation source files from the
105# ZEPHYR_BASE/ environment variable into the build directory,
Marti Bolivard7dc1132018-10-16 08:39:35 -0600106#
107# We need to make copies because Sphinx requires a single
108# documentation root directory, but Zephyr's documentation is
109# scattered around the tree in samples/, boards/, and doc/. Putting
110# them into a single rooted tree in the build directory is a
111# workaround for this limitation.
Marti Bolivar0913c292018-10-09 12:42:03 -0600112set(EXTRACT_CONTENT_COMMAND
113 ${CMAKE_COMMAND} -E env
Marti Bolivarf3d13862019-05-10 04:23:23 -0600114 ZEPHYR_BASE=${ZEPHYR_BASE}
Marti Bolivar0913c292018-10-09 12:42:03 -0600115 ${PYTHON_EXECUTABLE} scripts/extract_content.py
Marti Bolivar0913c292018-10-09 12:42:03 -0600116 # Ignore any files in the output directory.
117 --ignore ${CMAKE_CURRENT_BINARY_DIR}
118 # Copy all files in doc to the rst folder.
119 "*:doc:${RST_OUT}"
Marti Bolivard7dc1132018-10-16 08:39:35 -0600120 # We want to copy the .rst files in samples/ and boards/ to the rst
121 # folder, and also the doc folder inside rst.
Marti Bolivar0913c292018-10-09 12:42:03 -0600122 #
123 # Some files refer to items in samples/ and boards/ relative to
124 # their actual position in the Zephyr tree. For example, in
125 # subsystems/sensor.rst:
126 #
127 # .. literalinclude:: ../../samples/sensor/mcp9808/src/main.c
128 #
Marti Bolivard7dc1132018-10-16 08:39:35 -0600129 # The additional copy is a hackaround so these references work.
Marti Bolivar0913c292018-10-09 12:42:03 -0600130 "*.rst:samples:${RST_OUT}" "*.rst:boards:${RST_OUT}"
131 "*.rst:samples:${RST_OUT}/doc" "*.rst:boards:${RST_OUT}/doc")
132
Carles Cufi15fbf702018-12-06 12:21:48 +0100133add_custom_target(
134 content
135 # Copy all files in doc/ to the rst folder
Marti Bolivar0913c292018-10-09 12:42:03 -0600136 COMMAND ${EXTRACT_CONTENT_COMMAND}
137 WORKING_DIRECTORY ${CMAKE_CURRENT_LIST_DIR}
Marc Herbertfc644812019-02-15 10:41:25 -0800138 COMMENT "Copying files to ${RST_OUT}"
Carles Cufi15fbf702018-12-06 12:21:48 +0100139)
Marti Bolivar0913c292018-10-09 12:42:03 -0600140
Marc Herbert2270f4b2019-02-15 11:49:49 -0800141# For incremental builds not to miss any source change this MUST be kept
142# a superset of INPUT= and FILE_PATTERNS= in zephyr.doxyfile.in
Kumar Galaf80f31e2020-10-16 12:47:21 -0500143#
144# NOTE: any changes here should be reflected in .github/workflows/doc-build.yml
Marc Herbert2270f4b2019-02-15 11:49:49 -0800145file(GLOB_RECURSE DOXY_SOURCES
146 ${ZEPHYR_BASE}/include/*.[c,h,S]
Andrew Boie8d40d872019-11-07 15:24:59 -0800147 ${ZEPHYR_BASE}/kernel/include/kernel_arch_interface.h
Marc Herbert2270f4b2019-02-15 11:49:49 -0800148 ${ZEPHYR_BASE}/lib/libc/*.[c,h,S]
David B. Kinderb30b52a2019-06-25 15:54:19 -0700149 ${ZEPHYR_BASE}/subsys/testsuite/ztest/include/*.[h,c,S]
Marc Herbert2270f4b2019-02-15 11:49:49 -0800150 ${ZEPHYR_BASE}/tests/*.[h,c,S]
151 )
152# For debug. Also find generated list in doc/_build/(build.ninja|CMakeFiles/)
153# message("DOXY_SOURCES= " ${DOXY_SOURCES})
Carles Cufiae699342018-07-09 14:12:17 +0200154
Marc Herbert2270f4b2019-02-15 11:49:49 -0800155set(ARGS ${DOXYFILE_OUT})
156set(DOXY_RUN_TSTAMP ${CMAKE_CURRENT_BINARY_DIR}/last_doxy_run_tstamp)
157
158
159# Create timestamp first so we re-run if source files are edited while
160# doxygen is running
161add_custom_command(
162 OUTPUT ${DOXY_RUN_TSTAMP}
163 COMMAND cmake -E touch ${DOXY_RUN_TSTAMP}
Carles Cufiae699342018-07-09 14:12:17 +0200164 COMMAND ${CMAKE_COMMAND}
165 -DCOMMAND=${DOXYGEN_EXECUTABLE}
166 -DARGS="${ARGS}"
167 -DOUTPUT_FILE=${DOXY_LOG}
168 -DERROR_FILE=${DOXY_LOG}
Carles Cufi2af9a9e2018-07-13 15:32:36 +0200169 -DWORKING_DIRECTORY=${CMAKE_CURRENT_LIST_DIR}
Carles Cufi45d58a72018-07-12 17:34:29 +0200170 -P ${ZEPHYR_BASE}/cmake/util/execute_process.cmake
Marc Herbert2270f4b2019-02-15 11:49:49 -0800171 DEPENDS ${DOXY_SOURCES}
Marc Herbertfc644812019-02-15 10:41:25 -0800172 COMMENT "Running ${DOXYGEN_EXECUTABLE}"
Carles Cufiae699342018-07-09 14:12:17 +0200173)
174
Marc Herbert52842312019-02-07 13:39:59 -0800175# Doxygen doesn't support incremental builds.
176# It could be ok because it's pretty fast.
177# But it's not because it has a cascade effect on sphinx:
178# https://sourceforge.net/p/doxygen/mailman/message/36580807/
179# For now this optimization speeds-up non-doxygen documentation work
180# only (by one order of magnitude).
181add_custom_target(
182 doxy_real_modified_times
183 COMMAND ${CMAKE_COMMAND} -E env
184 ${PYTHON_EXECUTABLE} scripts/restore_modification_times.py
Marc Herbertfc644812019-02-15 10:41:25 -0800185 --loglevel WARN ${DOXY_OUT}/xml
Marc Herbert52842312019-02-07 13:39:59 -0800186 WORKING_DIRECTORY ${CMAKE_CURRENT_LIST_DIR}
Marc Herbert2270f4b2019-02-15 11:49:49 -0800187 DEPENDS ${DOXY_RUN_TSTAMP}
188 COMMENT "Fixing modification times of ${DOXY_OUT}/xml/ output"
Marc Herbert52842312019-02-07 13:39:59 -0800189)
190
Carles Cufiae699342018-07-09 14:12:17 +0200191add_custom_target(
192 pristine
193 COMMAND ${CMAKE_COMMAND} -P ${ZEPHYR_BASE}/cmake/pristine.cmake
Carles Cufiae699342018-07-09 14:12:17 +0200194)
195
Carles Cufiae699342018-07-09 14:12:17 +0200196if(WIN32)
Carles Cufi8645cc22019-09-06 15:56:21 +0200197 set(SEP $<SEMICOLON>)
Carles Cufiae699342018-07-09 14:12:17 +0200198else()
199 set(SEP :)
200endif()
201
Martí Bolívar808dd9e2020-10-12 11:02:46 -0700202set(KI_SCRIPT ${ZEPHYR_BASE}/scripts/filter-known-issues.py)
203set(FIX_TEX_SCRIPT ${ZEPHYR_BASE}/doc/scripts/fix_tex.py)
204set(CONF_DIR ${ZEPHYR_BASE}/.known-issues/doc)
205
206#
207# Generated Kconfig .rst documents
208#
209
Torsten Rasmussen5f7cc8d2020-07-06 12:53:39 +0200210file(WRITE ${KCONFIG_BINARY_DIR}/Kconfig.soc.defconfig
211 "osource \"${ZEPHYR_BASE}/soc/$(ARCH)/*/Kconfig.defconfig\"\n"
212)
213file(WRITE ${KCONFIG_BINARY_DIR}/Kconfig.soc
214 "osource \"${ZEPHYR_BASE}/soc/$(ARCH)/*/Kconfig.soc\"\n"
215)
Fabio Utzig4b93fdb2020-11-13 10:49:04 -0300216file(WRITE ${KCONFIG_BINARY_DIR}/Kconfig.shield.defconfig
217 "osource \"${ZEPHYR_BASE}/boards/shields/*/Kconfig.defconfig\"\n"
218)
219file(WRITE ${KCONFIG_BINARY_DIR}/Kconfig.shield
220 "osource \"${ZEPHYR_BASE}/boards/shields/*/Kconfig.shield\"\n"
221)
Torsten Rasmussen5f7cc8d2020-07-06 12:53:39 +0200222file(WRITE ${KCONFIG_BINARY_DIR}/Kconfig.soc.arch
223 "osource \"${ZEPHYR_BASE}/soc/$(ARCH)/Kconfig\"\n"
224 "osource \"${ZEPHYR_BASE}/soc/$(ARCH)/*/Kconfig\"\n"
225)
226
Carles Cufiae699342018-07-09 14:12:17 +0200227add_custom_target(
228 kconfig
Carles Cufie182dbc2018-07-16 19:05:05 +0200229 COMMAND ${CMAKE_COMMAND} -E make_directory ${RST_OUT}/doc/reference/kconfig
230 COMMAND ${CMAKE_COMMAND} -E env
Ulf Magnussonf570f192019-12-03 17:07:53 +0100231 PYTHONPATH=${ZEPHYR_BASE}/scripts/kconfig${SEP}$ENV{PYTHONPATH}
Marti Bolivarf3d13862019-05-10 04:23:23 -0600232 ZEPHYR_BASE=${ZEPHYR_BASE}
Carles Cufiae699342018-07-09 14:12:17 +0200233 srctree=${ZEPHYR_BASE}
Ulf Magnusson82330172019-10-21 20:20:18 +0200234 BOARD_DIR=boards/*/*
Ulf Magnussond0e87522018-09-05 12:58:05 +0200235 ARCH=*
Ulf Magnusson82330172019-10-21 20:20:18 +0200236 ARCH_DIR=arch
237 SOC_DIR=soc
Torsten Rasmussen5f7cc8d2020-07-06 12:53:39 +0200238 KCONFIG_BINARY_DIR=${KCONFIG_BINARY_DIR}
Carles Cufic6249ac2019-03-28 17:51:39 +0100239 KCONFIG_WARN_UNDEF=y
Anas Nashif940a9312019-01-21 13:58:05 -0500240 KCONFIG_TURBO_MODE=${KCONFIG_TURBO_MODE}
Carles Cufifa26ef02019-01-30 17:54:21 +0100241 KCONFIG_DOC_MODE=1
Martí Bolívar808dd9e2020-10-12 11:02:46 -0700242 ${PYTHON_EXECUTABLE} scripts/gen_kconfig_rest.py ${RST_OUT}/doc/reference/kconfig/
Ulf Magnusson5c28f392019-12-10 15:11:01 +0100243 --separate-all-index
Ulf Magnusson91c8ffa2019-11-21 19:37:58 +0100244 --keep-module-paths
Ulf Magnussonf570f192019-12-03 17:07:53 +0100245 --modules Architecture,arch,${ZEPHYR_BASE}/arch
246 Driver,drivers,${ZEPHYR_BASE}/drivers
247 Kernel,kernel,${ZEPHYR_BASE}/kernel
248 Library,lib,${ZEPHYR_BASE}/lib
249 Subsystem,subsys,${ZEPHYR_BASE}/subsys
250 "External Module,modules,${ZEPHYR_BASE}/modules"
Ulf Magnusson91c8ffa2019-11-21 19:37:58 +0100251
Ulf Magnussonf570f192019-12-03 17:07:53 +0100252 VERBATIM
Carles Cufi2af9a9e2018-07-13 15:32:36 +0200253 WORKING_DIRECTORY ${CMAKE_CURRENT_LIST_DIR}
Martí Bolívar808dd9e2020-10-12 11:02:46 -0700254 COMMENT "Running gen_kconfig_rest.py ${RST_OUT}/doc/reference/kconfig/"
Carles Cufiae699342018-07-09 14:12:17 +0200255)
256
Martí Bolívar808dd9e2020-10-12 11:02:46 -0700257#
258# Generated devicetree .rst documents
259#
260# The devicetree bindings discovered in ${DTS_ROOTS} are parsed and
261# documentation for them is generated in the directory
262# ${DTS_BINDINGS_RST_OUT}.
263#
264# The CMake variable GEN_DEVICETREE_REST_ZEPHYR_DOCSET will
265# be passed to the script in the environment. This allows separating
266# the bindings documentation into a standalone Sphinx docset that
267# nonetheless can link to Zephyr documentation using intersphinx.
268# If empty, the variable has no effect on the script.
269#
270# If not set, these are the default values for these variables:
271#
272# - DTS_ROOTS: ZEPHYR_BASE
273# - DTS_BINDINGS_RST_OUT: ${RST_OUT}/doc/reference/devicetree
274#
275
276set(GEN_DEVICETREE_REST_SCRIPT ${CMAKE_CURRENT_LIST_DIR}/scripts/gen_devicetree_rest.py)
277
278if(NOT DTS_ROOTS)
279 set(DTS_ROOTS ${ZEPHYR_BASE})
280endif()
281
282set(DTS_ROOT_ARGS)
283foreach(root ${DTS_ROOTS})
284 list(APPEND DTS_ROOT_ARGS --dts-root ${root})
285endforeach()
286
287if(NOT DTS_BINDINGS_RST_OUT)
288 set(DTS_BINDINGS_RST_OUT ${RST_OUT}/doc/reference/devicetree)
289endif()
290
291add_custom_target(
292 devicetree
293 COMMAND ${CMAKE_COMMAND} -E env
294 PYTHONPATH=${ZEPHYR_BASE}/scripts/dts${SEP}$ENV{PYTHONPATH}
295 ZEPHYR_BASE=${ZEPHYR_BASE}
296 GEN_DEVICETREE_REST_ZEPHYR_DOCSET=${GEN_DEVICETREE_REST_ZEPHYR_DOCSET}
297 ${PYTHON_EXECUTABLE} ${GEN_DEVICETREE_REST_SCRIPT}
298 --vendor-prefixes ${ZEPHYR_BASE}/dts/bindings/vendor-prefixes.txt
299 ${DTS_ROOT_ARGS} ${DTS_BINDINGS_RST_OUT}
300 VERBATIM
301 WORKING_DIRECTORY ${CMAKE_CURRENT_LIST_DIR}
302 COMMENT "Running gen_devicetree_rest.py ${DTS_BINDINGS_RST_OUT}"
303 USES_TERMINAL
304)
305
306set_property(DIRECTORY APPEND PROPERTY CMAKE_CONFIGURE_DEPENDS ${GEN_DEVICETREE_REST_SCRIPT})
Carles Cufiae699342018-07-09 14:12:17 +0200307
Daniel Leung9945e7f2018-08-23 11:11:11 -0700308#
309# HTML section
310#
Marti Bolivard9f512c2018-10-09 14:24:34 -0600311set(SPHINX_BUILD_HTML_COMMAND
312 ${CMAKE_COMMAND} -E env
Marti Bolivarf3d13862019-05-10 04:23:23 -0600313 ZEPHYR_BASE=${ZEPHYR_BASE}
Marti Bolivard9f512c2018-10-09 14:24:34 -0600314 ZEPHYR_BUILD=${CMAKE_CURRENT_BINARY_DIR}
315 ${SPHINXBUILD} -w ${SPHINX_LOG} -N -t ${DOC_TAG} -b html ${ALLSPHINXOPTS} ${RST_OUT}/doc ${SPHINX_OUTPUT_DIR_HTML})
316
317# The sphinx-html target is provided as a convenience for incremental
318# re-builds of content files without regenerating the entire docs
319# pipeline. It can be significantly faster than re-running the full
320# HTML build, but it has no idea if Doxygen, Kconfig, etc. need to be
321# regenerated. Use with caution.
322add_custom_target(
323 sphinx-html
324 COMMAND ${SPHINX_BUILD_HTML_COMMAND}
Marti Bolivard9f512c2018-10-09 14:24:34 -0600325 COMMENT "Just re-generating HTML (USE WITH CAUTION)"
Marc Herberte3c50af2020-10-07 06:59:33 +0000326 WORKING_DIRECTORY ${CMAKE_CURRENT_LIST_DIR}
Marti Bolivard9f512c2018-10-09 14:24:34 -0600327 USES_TERMINAL
328)
Marc Herberte3c50af2020-10-07 06:59:33 +0000329add_dependencies(sphinx-html content)
Marti Bolivard9f512c2018-10-09 14:24:34 -0600330
Marc Herbertfc644812019-02-15 10:41:25 -0800331# "breathe", the sphinx plugin that parses XML output from doxygen, has
332# an "everything on everything" dependency issue reported at:
333# https://github.com/michaeljones/breathe/issues/420 In other words
334# changing 1 source file costs the same build time than changing all
335# source files. breathe is fortunately smart enough not to run at all
336# when *nothing* has changed.
Carles Cufiae699342018-07-09 14:12:17 +0200337add_custom_target(
338 html
Marti Bolivard9f512c2018-10-09 14:24:34 -0600339 COMMAND ${SPHINX_BUILD_HTML_COMMAND}
Carles Cufiae699342018-07-09 14:12:17 +0200340 # Merge the Doxygen and Sphinx logs into a single file
341 COMMAND ${CMAKE_COMMAND} -P ${ZEPHYR_BASE}/cmake/util/fmerge.cmake ${DOC_LOG} ${DOXY_LOG} ${SPHINX_LOG}
Ulf Magnusson259c2402019-03-05 01:54:15 +0100342 COMMAND ${PYTHON_EXECUTABLE} ${KI_SCRIPT} --config-dir ${CONF_DIR} --errors ${DOC_WARN} --warnings ${DOC_WARN} ${DOC_LOG}
Carles Cufi2af9a9e2018-07-13 15:32:36 +0200343 WORKING_DIRECTORY ${CMAKE_CURRENT_LIST_DIR}
Marc Herbertfc644812019-02-15 10:41:25 -0800344 COMMENT "Generating HTML documentation with ${SPHINXBUILD} ${SPHINXOPTS}"
Carles Cufi60c55402018-07-15 18:57:01 +0200345 ${SPHINX_USES_TERMINAL}
Carles Cufiae699342018-07-09 14:12:17 +0200346)
Carles Cufi78964512018-07-15 18:49:37 +0200347
Daniel Leung9945e7f2018-08-23 11:11:11 -0700348#
349# LaTEX section
350#
Marti Bolivard9f512c2018-10-09 14:24:34 -0600351set(SPHINX_BUILD_LATEX_COMMAND
352 ${CMAKE_COMMAND} -E env
353 ZEPHYR_BUILD=${CMAKE_CURRENT_BINARY_DIR}
354 ${SPHINXBUILD} -w ${SPHINX_LOG} -N -t ${DOC_TAG} -b latex -t svgconvert ${ALLSPHINXOPTS} ${RST_OUT}/doc ${SPHINX_OUTPUT_DIR_LATEX})
355
356# The sphinx-latex target works similarly to sphinx-html, and carries
357# the same warnings.
358add_custom_target(
359 sphinx-latex
360 COMMAND ${SPHINX_BUILD_LATEX_COMMAND}
Marti Bolivard9f512c2018-10-09 14:24:34 -0600361 COMMENT "Just re-generating LaTeX (USE WITH CAUTION)"
Marc Herberte3c50af2020-10-07 06:59:33 +0000362 WORKING_DIRECTORY ${CMAKE_CURRENT_LIST_DIR}
Marti Bolivard9f512c2018-10-09 14:24:34 -0600363 USES_TERMINAL
364)
Marc Herberte3c50af2020-10-07 06:59:33 +0000365add_dependencies(sphinx-latex content)
366
Marti Bolivard9f512c2018-10-09 14:24:34 -0600367
Daniel Leungc164c8e2018-09-10 17:29:20 -0700368add_custom_command(
369 OUTPUT ${SPHINX_OUTPUT_DIR_LATEX}/zephyr.tex
Marti Bolivard9f512c2018-10-09 14:24:34 -0600370 COMMAND ${SPHINX_BUILD_LATEX_COMMAND}
Daniel Leung9945e7f2018-08-23 11:11:11 -0700371 # Merge the Doxygen and Sphinx logs into a single file
372 COMMAND ${CMAKE_COMMAND} -P ${ZEPHYR_BASE}/cmake/util/fmerge.cmake ${DOC_LOG} ${DOXY_LOG} ${SPHINX_LOG}
Ulf Magnusson259c2402019-03-05 01:54:15 +0100373 COMMAND ${PYTHON_EXECUTABLE} ${KI_SCRIPT} --config-dir ${CONF_DIR} --errors ${DOC_WARN} --warnings ${DOC_WARN} ${DOC_LOG}
Daniel Leung9945e7f2018-08-23 11:11:11 -0700374 COMMAND ${PYTHON_EXECUTABLE} ${FIX_TEX_SCRIPT} ${SPHINX_OUTPUT_DIR_LATEX}/zephyr.tex
375 WORKING_DIRECTORY ${CMAKE_CURRENT_LIST_DIR}
Marti Bolivard9f512c2018-10-09 14:24:34 -0600376 COMMENT "Generating LaTeX documentation"
Carles Cufi7599fad2018-09-26 11:22:32 +0200377 ${SPHINX_USES_TERMINAL}
Daniel Leungc164c8e2018-09-10 17:29:20 -0700378)
379
380add_custom_target(
381 latex
382 DEPENDS ${SPHINX_OUTPUT_DIR_LATEX}/zephyr.tex
Daniel Leung9945e7f2018-08-23 11:11:11 -0700383)
384
385#
386# PDF section
387#
388if(NOT ${LATEXMK} STREQUAL LATEXMK-NOTFOUND)
389
390add_custom_command(
391 OUTPUT ${SPHINX_OUTPUT_DIR_LATEX}/zephyr.pdf
392 DEPENDS latexdocs ${SPHINX_OUTPUT_DIR_LATEX}/zephyr.tex
393 COMMAND ${CMAKE_COMMAND} -E env
Carles Cufi0698dba2018-10-02 10:30:39 +0200394 LATEXOPTS="-halt-on-error -no-shell-escape"
Daniel Leung9945e7f2018-08-23 11:11:11 -0700395 ${LATEXMK} -quiet -pdf -dvi- -ps-
396 WORKING_DIRECTORY ${SPHINX_OUTPUT_DIR_LATEX}
Marti Bolivard9f512c2018-10-09 14:24:34 -0600397 COMMENT "Generating PDF documentation"
Daniel Leung9945e7f2018-08-23 11:11:11 -0700398)
399
400if(NOT DEFINED SPHINX_OUTPUT_DIR)
401# Although latexmk allows specifying output directory,
402# makeindex fails if one is specified.
403# Hence the need of this to copy the PDF file over.
404add_custom_command(
405 OUTPUT ${SPHINX_OUTPUT_DIR_PDF}/zephyr.pdf
406 COMMAND ${CMAKE_COMMAND} -E make_directory ${SPHINX_OUTPUT_DIR_PDF}
407 COMMAND ${CMAKE_COMMAND} -E copy ${SPHINX_OUTPUT_DIR_LATEX}/zephyr.pdf ${SPHINX_OUTPUT_DIR_PDF}/zephyr.pdf
408 DEPENDS ${SPHINX_OUTPUT_DIR_LATEX}/zephyr.pdf
409)
410endif()
411
412add_custom_target(
413 pdf
414 DEPENDS ${SPHINX_OUTPUT_DIR_PDF}/zephyr.pdf
Daniel Leung9945e7f2018-08-23 11:11:11 -0700415)
416
417endif()
418
419#
420# Dependencies and final targets
421#
Martí Bolívar808dd9e2020-10-12 11:02:46 -0700422add_dependencies(html content doxy_real_modified_times kconfig devicetree)
Carles Cufi78964512018-07-15 18:49:37 +0200423
424add_custom_target(
425 htmldocs
426)
427add_dependencies(htmldocs html)
428
Anas Nashif0a58fe82020-04-10 08:07:55 -0400429
430add_custom_target(
431 doxygen
432)
433add_dependencies(doxygen doxy_real_modified_times)
434
Martí Bolívar808dd9e2020-10-12 11:02:46 -0700435add_dependencies(latex content doxy_real_modified_times kconfig devicetree)
Daniel Leung9945e7f2018-08-23 11:11:11 -0700436
437add_custom_target(
438 latexdocs
439)
440add_dependencies(latexdocs latex)
441
442if(NOT ${LATEXMK} STREQUAL LATEXMK-NOTFOUND)
443
444add_custom_target(
445 pdfdocs
Daniel Leungc164c8e2018-09-10 17:29:20 -0700446 DEPENDS latexdocs pdf
Daniel Leung9945e7f2018-08-23 11:11:11 -0700447)
448add_dependencies(pdfdocs pdf)
449
450endif()