blob: ddf849b3a585b5edf7e4e0f52db4d9eaebbf3e47 [file] [log] [blame]
Gyorgy Szing74dae3c2018-09-27 17:00:46 +02001# -*- coding: utf-8 -*-
2#-------------------------------------------------------------------------------
Anton Komlevf7836d12021-12-23 16:27:46 +00003# Copyright (c) 2019-2022, Arm Limited. All rights reserved.
Gyorgy Szing74dae3c2018-09-27 17:00:46 +02004#
5# SPDX-License-Identifier: BSD-3-Clause
6#
7#-------------------------------------------------------------------------------#
8
9# Configuration file for the Sphinx documentation builder.
10#
11# This file does only contain a selection of the most common options. For a
12# full list see the documentation:
13# http://www.sphinx-doc.org/en/master/config
14
15# -- Path setup --------------------------------------------------------------
16
17# If extensions (or modules to document with autodoc) are in another directory,
18# add these directories to sys.path here. If the directory is relative to the
19# documentation root, use os.path.abspath to make it absolute, like shown here.
20#
21import os
22import sys
23sys.path.insert(0, os.path.abspath('..'))
24sys.path.insert(0, os.path.abspath('../docs'))
25
26# -- Project information -----------------------------------------------------
27
Galanakis, Minos35fc4472019-10-01 15:19:52 +010028project = 'Trusted Firmware-M'
Anton Komlevf7836d12021-12-23 16:27:46 +000029copyright = '2017-2022, ARM CE-OSS'
Gyorgy Szing74dae3c2018-09-27 17:00:46 +020030author = 'ARM CE-OSS'
Galanakis, Minos35fc4472019-10-01 15:19:52 +010031title = 'User Guide'
Gyorgy Szing74dae3c2018-09-27 17:00:46 +020032
Anton Komlevf7836d12021-12-23 16:27:46 +000033# The project version in the form: "vX.Y.Z" in case of clear release
34# or "vX.Y.Z+ (latest SHA)" if an update was posted.
Gyorgy Szing74dae3c2018-09-27 17:00:46 +020035version = '@SPHINXCFG_TFM_VERSION@'
Anton Komlevf7836d12021-12-23 16:27:46 +000036# Do not distinguish between release and version in Shpinx
37release = version
Gyorgy Szing74dae3c2018-09-27 17:00:46 +020038
39
40# -- General configuration ---------------------------------------------------
41
42# If your documentation needs a minimal Sphinx version, state it here.
43#
Gyorgy Szingdb9783c2019-04-17 21:08:48 +020044# needs_sphinx = '1.4'
Gyorgy Szing74dae3c2018-09-27 17:00:46 +020045
46# Add any Sphinx extension module names here, as strings. They can be
47# extensions coming with Sphinx (named 'sphinx.ext.*') or your custom
48# ones.
49extensions = [
50 'sphinx.ext.imgmath',
Anton Komlev27a52c22021-10-16 02:04:09 +010051 'm2r2', #Support markdown files. Needed for external code.
Gyorgy Szingdb9783c2019-04-17 21:08:48 +020052 'sphinx.ext.autosectionlabel', #Make sphinx generate a label for each section
Summer Qine99f95f2021-04-25 11:28:39 +080053 'sphinxcontrib.plantuml', #Add support for PlantUML drawings
Summer Qin0c20bcc2021-05-10 11:03:04 +080054 'sphinxcontrib.rsvgconverter', #Add support for SVG to PDF
55 'sphinx_tabs.tabs' #Enable tab extension in Sphinx
Gyorgy Szing74dae3c2018-09-27 17:00:46 +020056]
57
Gyorgy Szingdb9783c2019-04-17 21:08:48 +020058#Location of PlantUML
59plantuml = '@Java_JAVA_EXECUTABLE@ -jar @PLANTUML_JAR_PATH@'
60
61#Make auso section labals generated be prefixed with file name.
62autosectionlabel_prefix_document=True
Galanakis, Minosf56baf62019-11-11 13:57:42 +000063#Add auso section label for level 2 headers only.
64autosectionlabel_maxdepth=2
Gyorgy Szingdb9783c2019-04-17 21:08:48 +020065
Gyorgy Szing74dae3c2018-09-27 17:00:46 +020066# Add any paths that contain templates here, relative to this directory.
67templates_path = ['_templates']
68
69# The suffix(es) of source filenames.
70# You can specify multiple suffix as a list of string:
71#
72source_suffix = ['.rst', '.md']
73
74# The master toctree document.
75master_doc = 'index'
76
77# The language for content autogenerated by Sphinx. Refer to documentation
78# for a list of supported languages.
79#
80# This is also used if you do content translation via gettext catalogs.
81# Usually you set "language" from the command line for these cases.
82language = None
83
84# List of patterns, relative to source directory, that match files and
85# directories to ignore when looking for source files.
86# This pattern also affects html_static_path and html_extra_path .
Galanakis, Minosdc6694b2020-01-06 13:54:56 +000087exclude_patterns = ['_build', 'Thumbs.db', '.DS_Store', 'readme.rst',
Minos Galanakis56cb7592020-02-10 10:40:12 +000088 'platform/ext/target/cypress/psoc64/security/keys/readme.rst',
89 'lib/ext/**']
Gyorgy Szing74dae3c2018-09-27 17:00:46 +020090
91# The name of the Pygments (syntax highlighting) style to use.
92pygments_style = 'sphinx'
93
94
95# -- Options for HTML output -------------------------------------------------
96
97# The theme to use for HTML and HTML Help pages. See the documentation for
98# a list of builtin themes.
99#
100html_theme = 'sphinx_rtd_theme'
101
102# Theme options are theme-specific and customize the look and feel of a theme
103# further. For a list of options available for each theme, see the
104# documentation.
105#
Galanakis, Minos35fc4472019-10-01 15:19:52 +0100106html_theme_options = {'collapse_navigation': False}
Gyorgy Szingdb9783c2019-04-17 21:08:48 +0200107#
Gyorgy Szing74dae3c2018-09-27 17:00:46 +0200108# Add any paths that contain custom static files (such as style sheets) here,
109# relative to this directory. They are copied after the builtin static files,
110# so a file named "default.css" will overwrite the builtin "default.css".
Gyorgy Szingdb9783c2019-04-17 21:08:48 +0200111html_static_path = ['@TFM_ROOT_DIR@/docs/_static']
Gyorgy Szing74dae3c2018-09-27 17:00:46 +0200112
Galanakis, Minos35fc4472019-10-01 15:19:52 +0100113# Set the documentation logo
114html_logo = '@TFM_ROOT_DIR@/docs/_static/images/tf_logo_white.png'
115
Gyorgy Szing74dae3c2018-09-27 17:00:46 +0200116# Custom sidebar templates, must be a dictionary that maps document names
117# to template names.
118#
119# The default sidebars (for documents that don't match any pattern) are
120# defined by theme itself. Builtin themes are using these templates by
121# default: ``['localtoc.html', 'relations.html', 'sourcelink.html',
122# 'searchbox.html']``.
123#
124# html_sidebars = {}
125
126#Disable adding conf.py copyright notice to HTML output
127html_show_copyright = False
128
Gyorgy Szingdb9783c2019-04-17 21:08:48 +0200129#Add custom css for HTML. Used to allow full page width rendering
130def setup(app):
Anton Komlev27a52c22021-10-16 02:04:09 +0100131 app.add_css_file('css/tfm_custom.css')
Gyorgy Szingdb9783c2019-04-17 21:08:48 +0200132
Gyorgy Szing74dae3c2018-09-27 17:00:46 +0200133# -- Options for HTMLHelp output ---------------------------------------------
134
135# Output file base name for HTML help builder.
136htmlhelp_basename = 'TF-M doc'
137
Galanakis, Minosdc6694b2020-01-06 13:54:56 +0000138rst_prolog = """
139.. |TFM_VERSION| replace:: @SPHINXCFG_TFM_VERSION@
140"""
Gyorgy Szing74dae3c2018-09-27 17:00:46 +0200141
Ken Liu40510162021-05-06 17:38:49 +0800142# Enable figures and tables auto numbering
143numfig = True
144numfig_secnum_depth = 0
145numfig_format = {
146 'figure': 'Figure %s:',
147 'table': 'Table %s:',
148 'code-block': 'Listing %s:',
149 'section': '%s'
150}
151
Gyorgy Szing74dae3c2018-09-27 17:00:46 +0200152# -- Options for LaTeX output ------------------------------------------------
153
154latex_elements = {
155 # The paper size ('letterpaper' or 'a4paper').
156 #
157 # 'papersize': 'letterpaper',
158
159 # The font size ('10pt', '11pt' or '12pt').
160 #
161 # 'pointsize': '10pt',
162
163 # Additional stuff for the LaTeX preamble.
164 #
165 # 'preamble': '',
166
167 # Latex figure (float) alignment
168 #
169 # 'figure_align': 'htbp',
170}
171
172# Grouping the document tree into LaTeX files. List of tuples
173# (source start file, target name, title,
174# author, documentclass [howto, manual, or own class]).
175latex_documents = [
176 (master_doc, 'TF-M.tex', title,
177 author, 'manual'),
178]
179
180
181# -- Options for manual page output ------------------------------------------
182
183# One entry per manual page. List of tuples
184# (source start file, name, description, authors, manual section).
185#man_pages = [
186# (master_doc, 'tf-m', title,
187# [author], 7)
188#]
189
190
191# -- Options for Texinfo output ----------------------------------------------
192
193# Grouping the document tree into Texinfo files. List of tuples
194# (source start file, target name, title, author,
195# dir menu entry, description, category)
196#texinfo_documents = [
197# (master_doc, 'TF-M', title,
198# author, 'TF-M', 'Trusted Firmware for Cortex-M',
199# 'Miscellaneous'),
200#]
201
202
203# -- Extension configuration -------------------------------------------------