blob: f3739be611c9b3b39bc1ed8d89738bf6aac33914 [file] [log] [blame]
Gyorgy Szing74dae3c2018-09-27 17:00:46 +02001# -*- coding: utf-8 -*-
2#-------------------------------------------------------------------------------
Galanakis, Minosdc6694b2020-01-06 13:54:56 +00003# Copyright (c) 2019-2020, 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'
Gyorgy Szing74dae3c2018-09-27 17:00:46 +020029copyright = '2017-2019, ARM CE-OSS'
30author = 'ARM CE-OSS'
Galanakis, Minos35fc4472019-10-01 15:19:52 +010031title = 'User Guide'
Gyorgy Szing74dae3c2018-09-27 17:00:46 +020032
33# The short X.Y version
34version = '@SPHINXCFG_TFM_VERSION@'
35# The full version, including alpha/beta/rc tags
36release = '@SPHINXCFG_TFM_VERSION_FULL@'
37
38
39# -- General configuration ---------------------------------------------------
40
41# If your documentation needs a minimal Sphinx version, state it here.
42#
Gyorgy Szingdb9783c2019-04-17 21:08:48 +020043# needs_sphinx = '1.4'
Gyorgy Szing74dae3c2018-09-27 17:00:46 +020044
45# Add any Sphinx extension module names here, as strings. They can be
46# extensions coming with Sphinx (named 'sphinx.ext.*') or your custom
47# ones.
48extensions = [
49 'sphinx.ext.imgmath',
Gyorgy Szingdb9783c2019-04-17 21:08:48 +020050 'm2r', #Support markdown files. Needed for external code.
51 'sphinx.ext.autosectionlabel', #Make sphinx generate a label for each section
52 'sphinxcontrib.plantuml' #Add support for PlantUML drawings
Gyorgy Szing74dae3c2018-09-27 17:00:46 +020053]
54
Gyorgy Szingdb9783c2019-04-17 21:08:48 +020055#Location of PlantUML
56plantuml = '@Java_JAVA_EXECUTABLE@ -jar @PLANTUML_JAR_PATH@'
57
58#Make auso section labals generated be prefixed with file name.
59autosectionlabel_prefix_document=True
Galanakis, Minosf56baf62019-11-11 13:57:42 +000060#Add auso section label for level 2 headers only.
61autosectionlabel_maxdepth=2
Gyorgy Szingdb9783c2019-04-17 21:08:48 +020062
Gyorgy Szing74dae3c2018-09-27 17:00:46 +020063# Add any paths that contain templates here, relative to this directory.
64templates_path = ['_templates']
65
66# The suffix(es) of source filenames.
67# You can specify multiple suffix as a list of string:
68#
69source_suffix = ['.rst', '.md']
70
71# The master toctree document.
72master_doc = 'index'
73
74# The language for content autogenerated by Sphinx. Refer to documentation
75# for a list of supported languages.
76#
77# This is also used if you do content translation via gettext catalogs.
78# Usually you set "language" from the command line for these cases.
79language = None
80
81# List of patterns, relative to source directory, that match files and
82# directories to ignore when looking for source files.
83# This pattern also affects html_static_path and html_extra_path .
Galanakis, Minosdc6694b2020-01-06 13:54:56 +000084exclude_patterns = ['_build', 'Thumbs.db', '.DS_Store', 'readme.rst',
Minos Galanakis56cb7592020-02-10 10:40:12 +000085 'platform/ext/target/cypress/psoc64/security/keys/readme.rst',
86 'lib/ext/**']
Gyorgy Szing74dae3c2018-09-27 17:00:46 +020087
88# The name of the Pygments (syntax highlighting) style to use.
89pygments_style = 'sphinx'
90
91
92# -- Options for HTML output -------------------------------------------------
93
94# The theme to use for HTML and HTML Help pages. See the documentation for
95# a list of builtin themes.
96#
97html_theme = 'sphinx_rtd_theme'
98
99# Theme options are theme-specific and customize the look and feel of a theme
100# further. For a list of options available for each theme, see the
101# documentation.
102#
Galanakis, Minos35fc4472019-10-01 15:19:52 +0100103html_theme_options = {'collapse_navigation': False}
Gyorgy Szingdb9783c2019-04-17 21:08:48 +0200104#
Gyorgy Szing74dae3c2018-09-27 17:00:46 +0200105# Add any paths that contain custom static files (such as style sheets) here,
106# relative to this directory. They are copied after the builtin static files,
107# so a file named "default.css" will overwrite the builtin "default.css".
Gyorgy Szingdb9783c2019-04-17 21:08:48 +0200108html_static_path = ['@TFM_ROOT_DIR@/docs/_static']
Gyorgy Szing74dae3c2018-09-27 17:00:46 +0200109
Galanakis, Minos35fc4472019-10-01 15:19:52 +0100110# Set the documentation logo
111html_logo = '@TFM_ROOT_DIR@/docs/_static/images/tf_logo_white.png'
112
Gyorgy Szing74dae3c2018-09-27 17:00:46 +0200113# Custom sidebar templates, must be a dictionary that maps document names
114# to template names.
115#
116# The default sidebars (for documents that don't match any pattern) are
117# defined by theme itself. Builtin themes are using these templates by
118# default: ``['localtoc.html', 'relations.html', 'sourcelink.html',
119# 'searchbox.html']``.
120#
121# html_sidebars = {}
122
123#Disable adding conf.py copyright notice to HTML output
124html_show_copyright = False
125
Gyorgy Szingdb9783c2019-04-17 21:08:48 +0200126#Add custom css for HTML. Used to allow full page width rendering
127def setup(app):
Minos Galanakise4094012020-06-12 14:25:34 +0100128 app.add_stylesheet('css/tfm_custom.css')
Gyorgy Szingdb9783c2019-04-17 21:08:48 +0200129
Gyorgy Szing74dae3c2018-09-27 17:00:46 +0200130# -- Options for HTMLHelp output ---------------------------------------------
131
132# Output file base name for HTML help builder.
133htmlhelp_basename = 'TF-M doc'
134
Galanakis, Minosdc6694b2020-01-06 13:54:56 +0000135rst_prolog = """
136.. |TFM_VERSION| replace:: @SPHINXCFG_TFM_VERSION@
137"""
Gyorgy Szing74dae3c2018-09-27 17:00:46 +0200138
139# -- Options for LaTeX output ------------------------------------------------
140
141latex_elements = {
142 # The paper size ('letterpaper' or 'a4paper').
143 #
144 # 'papersize': 'letterpaper',
145
146 # The font size ('10pt', '11pt' or '12pt').
147 #
148 # 'pointsize': '10pt',
149
150 # Additional stuff for the LaTeX preamble.
151 #
152 # 'preamble': '',
153
154 # Latex figure (float) alignment
155 #
156 # 'figure_align': 'htbp',
157}
158
159# Grouping the document tree into LaTeX files. List of tuples
160# (source start file, target name, title,
161# author, documentclass [howto, manual, or own class]).
162latex_documents = [
163 (master_doc, 'TF-M.tex', title,
164 author, 'manual'),
165]
166
167
168# -- Options for manual page output ------------------------------------------
169
170# One entry per manual page. List of tuples
171# (source start file, name, description, authors, manual section).
172#man_pages = [
173# (master_doc, 'tf-m', title,
174# [author], 7)
175#]
176
177
178# -- Options for Texinfo output ----------------------------------------------
179
180# Grouping the document tree into Texinfo files. List of tuples
181# (source start file, target name, title, author,
182# dir menu entry, description, category)
183#texinfo_documents = [
184# (master_doc, 'TF-M', title,
185# author, 'TF-M', 'Trusted Firmware for Cortex-M',
186# 'Miscellaneous'),
187#]
188
189
190# -- Extension configuration -------------------------------------------------