blob: 0ff0cb4707e6787fbdd504231ef69084cc0e60a1 [file] [log] [blame]
Anton Komlevb813dbc2022-04-01 21:12:16 +01001# -*- coding: utf-8 -*-
2#-------------------------------------------------------------------------------
Nicola Mazzucato3d9621e2025-03-24 11:12:55 +00003# SPDX-FileCopyrightText: Copyright The TrustedFirmware-M Contributors
Minos Galanakisd19a19f2020-06-03 15:38:03 +01004#
5# SPDX-License-Identifier: BSD-3-Clause
6#
Anton Komlevb813dbc2022-04-01 21:12:16 +01007#-------------------------------------------------------------------------------
8
9# Configuration file for the Sphinx documentation builder.
Minos Galanakisd19a19f2020-06-03 15:38:03 +010010#
Anton Komlevb813dbc2022-04-01 21:12:16 +010011# 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
Minos Galanakisd19a19f2020-06-03 15:38:03 +010015import os
16import sys
Anton Komlevb813dbc2022-04-01 21:12:16 +010017import re
18from subprocess import check_output
Minos Galanakisd19a19f2020-06-03 15:38:03 +010019
Anton Komlevb813dbc2022-04-01 21:12:16 +010020# -- Project information -----------------------------------------------------
Minos Galanakisd19a19f2020-06-03 15:38:03 +010021
Anton Komlevb813dbc2022-04-01 21:12:16 +010022project = 'Trusted Firmware-M'
Nicola Mazzucato3d9621e2025-03-24 11:12:55 +000023copyright = '2017-2025, ARM CE-OSS'
Anton Komlevb813dbc2022-04-01 21:12:16 +010024author = 'ARM CE-OSS'
25title = 'User Guide'
Minos Galanakisd19a19f2020-06-03 15:38:03 +010026
Anton Komlevb813dbc2022-04-01 21:12:16 +010027# -- Extract current version -------------------------------------------------
Minos Galanakisd19a19f2020-06-03 15:38:03 +010028
Anton Komlevb813dbc2022-04-01 21:12:16 +010029try:
30 vrex = re.compile(r'TF-M(?P<GIT_VERSION>v.+?)'
31 r'(-[0-9]+-g)?(?P<GIT_SHA>[a-f0-9]{7,})?$')
Minos Galanakisd19a19f2020-06-03 15:38:03 +010032
Anton Komlevb813dbc2022-04-01 21:12:16 +010033 version = check_output("git describe --tags --always",
34 shell = True, encoding = 'UTF-8')
35
36 _v = vrex.match(version)
37 release = _v.group('GIT_VERSION')
38 if _v.group('GIT_SHA'):
39 version = release + "+" + _v.group('GIT_SHA')[:7]
40
41except:
42 version = release = 'Unknown'
43
44# -- General configuration ---------------------------------------------------
45
Anton Komlevb813dbc2022-04-01 21:12:16 +010046extensions = [
47 'sphinx.ext.imgmath',
48 'm2r2', #Support markdown files. Needed for external code.
49 'sphinx.ext.autosectionlabel', #Make sphinx generate a label for each section
50 'sphinxcontrib.plantuml', #Add support for PlantUML drawings
51 'sphinxcontrib.rsvgconverter', #Add support for SVG to PDF
Antonio de Angelis671c9712023-02-15 22:40:32 +000052 'sphinx_tabs.tabs', #Enable tab extension in Sphinx
Elena Uziunaiteafcd4612023-11-07 16:49:48 +000053 'sphinx.ext.intersphinx', #Enable Intersphinx
Anton Komlevb813dbc2022-04-01 21:12:16 +010054]
55
Elena Uziunaiteafcd4612023-11-07 16:49:48 +000056intersphinx_mapping = {
57 "TF-M-Tests": ("https://trustedfirmware-m.readthedocs.io/projects/tf-m-tests/en/latest/", None),
58 "TF-M-Tools": ("https://trustedfirmware-m.readthedocs.io/projects/tf-m-tools/en/latest/", None),
59 "TF-M-Extras": ("https://trustedfirmware-m.readthedocs.io/projects/tf-m-extras/en/latest/", None),
60}
61
62intersphinx_disabled_reftypes = ["*"]
63
Elena Uziunaitea2ea43d2023-11-20 17:29:32 +000064#PlantUML
65if 'PLANTUML_JAR_PATH' in os.environ:
66 plantuml = 'java -jar ' + os.environ['PLANTUML_JAR_PATH']
67
Anton Komlev6f1e5492022-06-16 19:08:57 +010068# Make auto section labels generated be prefixed with file name.
Anton Komlevb813dbc2022-04-01 21:12:16 +010069autosectionlabel_prefix_document=True
Anton Komlev6f1e5492022-06-16 19:08:57 +010070# Add auto section label for level 2 headers only.
Anton Komlevb813dbc2022-04-01 21:12:16 +010071autosectionlabel_maxdepth=2
72
73# Add any paths that contain templates here, relative to this directory.
74templates_path = ['_templates']
75
76# The suffix(es) of source filenames.
77# You can specify multiple suffix as a list of string:
78#
79source_suffix = ['.rst', '.md']
80
81# The master toctree document.
82master_doc = 'index'
83
84# The language for content autogenerated by Sphinx. Refer to documentation
85# for a list of supported languages.
86#
87# This is also used if you do content translation via gettext catalogs.
88# Usually you set "language" from the command line for these cases.
89language = None
90
91# List of patterns, relative to source directory, that match files and
92# directories to ignore when looking for source files.
93# This pattern also affects html_static_path and html_extra_path .
94exclude_patterns = ['_build', 'Thumbs.db', '.DS_Store', 'readme.rst',
Anton Komlevde14f452022-06-19 15:45:26 +010095 'platform/cypress/psoc64/security/keys/readme.rst',
Anton Komlevb813dbc2022-04-01 21:12:16 +010096 'lib/ext/**']
97
98# The name of the Pygments (syntax highlighting) style to use.
99pygments_style = 'sphinx'
100
101# -- Options for HTML output -------------------------------------------------
102
Anton Komlevb813dbc2022-04-01 21:12:16 +0100103html_theme = 'sphinx_rtd_theme'
104
Anton Komlev8e448342022-04-06 10:19:35 +0100105html_theme_options = {
Anton Komlev91281f02022-04-22 09:24:20 +0100106 'collapse_navigation' : False,
107 'prev_next_buttons_location' : None, # Hide Prev and Next buttons
Anton Komlev6f1e5492022-06-16 19:08:57 +0100108 'display_version': True, # Show version under logo
Anton Komlev91281f02022-04-22 09:24:20 +0100109 'sticky_navigation': True,
Anton Komlev1f1bec02022-06-17 15:45:09 +0100110 'navigation_depth': 3,
Anton Komlev8e448342022-04-06 10:19:35 +0100111}
112
113# Remove the "View page source" link from the top of docs pages
114html_show_sourcelink = False
115
Anton Komlevb813dbc2022-04-01 21:12:16 +0100116# Add any paths that contain custom static files (such as style sheets) here,
117# relative to configuration directory. They are copied after the builtin static
118# files, so a file named "default.css" will overwrite the builtin "default.css".
119html_static_path = ['_static']
120
121# Set the documentation logo relative to configuration directory
122html_logo = '_static/images/tf_logo_white.png'
123
Anton Komlev8e448342022-04-06 10:19:35 +0100124# Set the documentation favicon
125html_favicon = '_static/images/favicon.ico'
126
Anton Komlevb813dbc2022-04-01 21:12:16 +0100127#Disable adding conf.py copyright notice to HTML output
128html_show_copyright = False
129
Anton Komlev8e448342022-04-06 10:19:35 +0100130# Disable showing Sphinx footer message:
131# "Built with Sphinx using a theme provided by Read the Docs. "
132html_show_sphinx = False
133
Anton Komlevb813dbc2022-04-01 21:12:16 +0100134#Add custom css for HTML. Used to allow full page width rendering
135def setup(app):
136 app.add_css_file('css/tfm_custom.css')
137
138# -- Options for HTMLHelp output ---------------------------------------------
139
140# Output file base name for HTML help builder.
141htmlhelp_basename = 'TF-M doc'
142
Anton Komlevb813dbc2022-04-01 21:12:16 +0100143# Enable figures and tables auto numbering
144numfig = True
145numfig_secnum_depth = 0
146numfig_format = {
147 'figure': 'Figure %s:',
148 'table': 'Table %s:',
149 'code-block': 'Listing %s:',
150 'section': '%s'
151}
152
153# -- Options for LaTeX output ------------------------------------------------
154
155latex_elements = {
Anton Komlevb813dbc2022-04-01 21:12:16 +0100156 # 'papersize': 'letterpaper',
Anton Komlevb813dbc2022-04-01 21:12:16 +0100157 # 'pointsize': '10pt',
Anton Komlevb813dbc2022-04-01 21:12:16 +0100158 # 'preamble': '',
Anton Komlevb813dbc2022-04-01 21:12:16 +0100159 # 'figure_align': 'htbp',
160}
161
162# Grouping the document tree into LaTeX files. List of tuples
163# (source start file, target name, title,
164# author, documentclass [howto, manual, or own class]).
165latex_documents = [
166 (master_doc, 'TF-M.tex', title,
167 author, 'manual'),
168]
169
Antonio de Angelis671c9712023-02-15 22:40:32 +0000170language = 'en'