blob: 93912b3bb939fbed1ce0b05e4b94d15d770f09b1 [file] [log] [blame]
Anton Komlevb813dbc2022-04-01 21:12:16 +01001# -*- coding: utf-8 -*-
2#-------------------------------------------------------------------------------
3# Copyright (c) 2019-2022, Arm Limited. All rights reserved.
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'
23copyright = '2017-2022, ARM CE-OSS'
24author = '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
46# If your documentation needs a minimal Sphinx version, state it here.
47#
48# needs_sphinx = '1.4'
49
50# Add any Sphinx extension module names here, as strings. They can be
51# extensions coming with Sphinx (named 'sphinx.ext.*') or your custom
52# ones.
53extensions = [
54 'sphinx.ext.imgmath',
55 'm2r2', #Support markdown files. Needed for external code.
56 'sphinx.ext.autosectionlabel', #Make sphinx generate a label for each section
57 'sphinxcontrib.plantuml', #Add support for PlantUML drawings
58 'sphinxcontrib.rsvgconverter', #Add support for SVG to PDF
59 'sphinx_tabs.tabs' #Enable tab extension in Sphinx
60]
61
62# PlantUML
63plantuml = 'java -jar ' + os.environ['PLANTUML_JAR_PATH']
64
65#Make auso section labals generated be prefixed with file name.
66autosectionlabel_prefix_document=True
67#Add auso section label for level 2 headers only.
68autosectionlabel_maxdepth=2
69
70# Add any paths that contain templates here, relative to this directory.
71templates_path = ['_templates']
72
73# The suffix(es) of source filenames.
74# You can specify multiple suffix as a list of string:
75#
76source_suffix = ['.rst', '.md']
77
78# The master toctree document.
79master_doc = 'index'
80
81# The language for content autogenerated by Sphinx. Refer to documentation
82# for a list of supported languages.
83#
84# This is also used if you do content translation via gettext catalogs.
85# Usually you set "language" from the command line for these cases.
86language = None
87
88# List of patterns, relative to source directory, that match files and
89# directories to ignore when looking for source files.
90# This pattern also affects html_static_path and html_extra_path .
91exclude_patterns = ['_build', 'Thumbs.db', '.DS_Store', 'readme.rst',
92 'platform/ext/target/cypress/psoc64/security/keys/readme.rst',
93 'lib/ext/**']
94
95# The name of the Pygments (syntax highlighting) style to use.
96pygments_style = 'sphinx'
97
98# -- Options for HTML output -------------------------------------------------
99
100# The theme to use for HTML and HTML Help pages. See the documentation for
101# a list of builtin themes.
102#
103html_theme = 'sphinx_rtd_theme'
104
105# Theme options are theme-specific and customize the look and feel of a theme
106# further. For a list of options available for each theme, see the
107# documentation.
108#
Anton Komlev8e448342022-04-06 10:19:35 +0100109html_theme_options = {
Anton Komlev91281f02022-04-22 09:24:20 +0100110 'collapse_navigation' : False,
111 'prev_next_buttons_location' : None, # Hide Prev and Next buttons
Anton Komlev8e448342022-04-06 10:19:35 +0100112# 'display_version': True, # Show version under logo
Anton Komlev91281f02022-04-22 09:24:20 +0100113 'sticky_navigation': True,
114 'navigation_depth': 2,
Anton Komlev8e448342022-04-06 10:19:35 +0100115}
116
117# Remove the "View page source" link from the top of docs pages
118html_show_sourcelink = False
119
Anton Komlevb813dbc2022-04-01 21:12:16 +0100120#
121# Add any paths that contain custom static files (such as style sheets) here,
122# relative to configuration directory. They are copied after the builtin static
123# files, so a file named "default.css" will overwrite the builtin "default.css".
124html_static_path = ['_static']
125
126# Set the documentation logo relative to configuration directory
127html_logo = '_static/images/tf_logo_white.png'
128
Anton Komlev8e448342022-04-06 10:19:35 +0100129# Set the documentation favicon
130html_favicon = '_static/images/favicon.ico'
131
Anton Komlevb813dbc2022-04-01 21:12:16 +0100132# Custom sidebar templates, must be a dictionary that maps document names
133# to template names.
134#
135# The default sidebars (for documents that don't match any pattern) are
136# defined by theme itself. Builtin themes are using these templates by
137# default: ``['localtoc.html', 'relations.html', 'sourcelink.html',
138# 'searchbox.html']``.
139#
140# html_sidebars = {}
141
142#Disable adding conf.py copyright notice to HTML output
143html_show_copyright = False
144
Anton Komlev8e448342022-04-06 10:19:35 +0100145# Disable showing Sphinx footer message:
146# "Built with Sphinx using a theme provided by Read the Docs. "
147html_show_sphinx = False
148
Anton Komlevb813dbc2022-04-01 21:12:16 +0100149#Add custom css for HTML. Used to allow full page width rendering
150def setup(app):
151 app.add_css_file('css/tfm_custom.css')
152
153# -- Options for HTMLHelp output ---------------------------------------------
154
155# Output file base name for HTML help builder.
156htmlhelp_basename = 'TF-M doc'
157
158rst_prolog = """
159.. |TFM_VERSION| replace:: version
160"""
161
162# Enable figures and tables auto numbering
163numfig = True
164numfig_secnum_depth = 0
165numfig_format = {
166 'figure': 'Figure %s:',
167 'table': 'Table %s:',
168 'code-block': 'Listing %s:',
169 'section': '%s'
170}
171
172# -- Options for LaTeX output ------------------------------------------------
173
174latex_elements = {
175 # The paper size ('letterpaper' or 'a4paper').
176 #
177 # 'papersize': 'letterpaper',
178
179 # The font size ('10pt', '11pt' or '12pt').
180 #
181 # 'pointsize': '10pt',
182
183 # Additional stuff for the LaTeX preamble.
184 #
185 # 'preamble': '',
186
187 # Latex figure (float) alignment
188 #
189 # 'figure_align': 'htbp',
190}
191
192# Grouping the document tree into LaTeX files. List of tuples
193# (source start file, target name, title,
194# author, documentclass [howto, manual, or own class]).
195latex_documents = [
196 (master_doc, 'TF-M.tex', title,
197 author, 'manual'),
198]
199
200# -- Options for manual page output ------------------------------------------
201
202# One entry per manual page. List of tuples
203# (source start file, name, description, authors, manual section).
204#man_pages = [
205# (master_doc, 'tf-m', title,
206# [author], 7)
207#]
208
209# -- Options for Texinfo output ----------------------------------------------
210
211# Grouping the document tree into Texinfo files. List of tuples
212# (source start file, target name, title, author,
213# dir menu entry, description, category)
214#texinfo_documents = [
215# (master_doc, 'TF-M', title,
216# author, 'TF-M', 'Trusted Firmware for Cortex-M',
217# 'Miscellaneous'),
218#]
219
220# -- Extension configuration -------------------------------------------------