2021-03-30 12:10:31 +02:00
|
|
|
# Zephyr documentation build configuration file.
|
|
|
|
# Reference: https://www.sphinx-doc.org/en/master/usage/configuration.html
|
2015-05-13 20:05:30 +02:00
|
|
|
|
|
|
|
import sys
|
|
|
|
import os
|
2021-03-30 14:38:59 +02:00
|
|
|
from pathlib import Path
|
2021-03-30 14:31:52 +02:00
|
|
|
import re
|
2023-10-19 18:46:47 +02:00
|
|
|
import textwrap
|
2015-05-13 20:05:30 +02:00
|
|
|
|
2021-07-20 14:25:27 +02:00
|
|
|
from sphinx.cmd.build import get_parser
|
2021-03-30 12:22:20 +02:00
|
|
|
|
2021-07-20 14:25:27 +02:00
|
|
|
args = get_parser().parse_args()
|
|
|
|
ZEPHYR_BASE = Path(__file__).resolve().parents[1]
|
|
|
|
ZEPHYR_BUILD = Path(args.outputdir).resolve()
|
2018-06-08 03:45:55 +02:00
|
|
|
|
2021-03-30 14:50:25 +02:00
|
|
|
# Add the '_extensions' directory to sys.path, to enable finding Sphinx
|
doc: add zephyr-app-commands directive
Add extensions/zephyr to the documentation. This is where Sphinx
extensions customized for Zephyr will live.
Within, add application.py. This provides a directive,
zephyr-app-commands, which generates commands in the docs to build,
flash, debug, etc. an application. For now, these are Unix shell
specific. Later on, they can be customized to generate additional
formats, perhaps with extra options.
After this is used throughout the tree, doing this with an extension
enables global changes with changes to the directive implementation
only.
Signed-off-by: Marti Bolivar <marti@opensourcefoundries.com>
2017-11-03 21:46:33 +01:00
|
|
|
# extensions within.
|
2021-03-30 14:50:25 +02:00
|
|
|
sys.path.insert(0, str(ZEPHYR_BASE / "doc" / "_extensions"))
|
2018-11-12 16:14:51 +01:00
|
|
|
|
2021-03-30 10:55:43 +02:00
|
|
|
# Add the '_scripts' directory to sys.path, to enable finding utility
|
|
|
|
# modules.
|
2021-03-30 14:50:25 +02:00
|
|
|
sys.path.insert(0, str(ZEPHYR_BASE / "doc" / "_scripts"))
|
2021-03-30 10:55:43 +02:00
|
|
|
|
2019-01-23 16:31:06 +01:00
|
|
|
# Add the directory which contains the runners package as well,
|
|
|
|
# for autodoc directives on runners.xyz.
|
2021-03-30 14:50:25 +02:00
|
|
|
sys.path.insert(0, str(ZEPHYR_BASE / "scripts" / "west_commands"))
|
2019-01-23 16:31:06 +01:00
|
|
|
|
2023-11-22 19:57:10 +01:00
|
|
|
# Add the directory which contains the pytest-twister-pytest
|
|
|
|
sys.path.insert(0, str(ZEPHYR_BASE / "scripts" / "pylib" / "pytest-twister-harness" / "src"))
|
|
|
|
|
2021-03-30 10:55:43 +02:00
|
|
|
import redirects
|
|
|
|
|
2018-11-12 16:14:51 +01:00
|
|
|
try:
|
2019-07-22 19:00:59 +02:00
|
|
|
import west as west_found
|
|
|
|
except ImportError:
|
|
|
|
west_found = False
|
2015-05-13 20:05:30 +02:00
|
|
|
|
2021-03-30 13:09:11 +02:00
|
|
|
# -- Project --------------------------------------------------------------
|
2015-05-13 20:05:30 +02:00
|
|
|
|
2021-03-30 14:50:25 +02:00
|
|
|
project = "Zephyr Project"
|
2024-01-05 13:37:19 +01:00
|
|
|
copyright = "2015-2024 Zephyr Project members and individual contributors"
|
2021-07-22 16:14:51 +02:00
|
|
|
author = "The Zephyr Project Contributors"
|
2015-05-13 20:05:30 +02:00
|
|
|
|
2021-03-30 14:31:52 +02:00
|
|
|
# parse version from 'VERSION' file
|
2021-03-30 14:50:25 +02:00
|
|
|
with open(ZEPHYR_BASE / "VERSION") as f:
|
2021-03-30 14:31:52 +02:00
|
|
|
m = re.match(
|
|
|
|
(
|
|
|
|
r"^VERSION_MAJOR\s*=\s*(\d+)$\n"
|
|
|
|
+ r"^VERSION_MINOR\s*=\s*(\d+)$\n"
|
|
|
|
+ r"^PATCHLEVEL\s*=\s*(\d+)$\n"
|
|
|
|
+ r"^VERSION_TWEAK\s*=\s*\d+$\n"
|
|
|
|
+ r"^EXTRAVERSION\s*=\s*(.*)$"
|
|
|
|
),
|
|
|
|
f.read(),
|
|
|
|
re.MULTILINE,
|
|
|
|
)
|
|
|
|
|
|
|
|
if not m:
|
2021-03-30 14:50:25 +02:00
|
|
|
sys.stderr.write("Warning: Could not extract kernel version\n")
|
2021-03-30 14:31:52 +02:00
|
|
|
version = "Unknown"
|
|
|
|
else:
|
|
|
|
major, minor, patch, extra = m.groups(1)
|
|
|
|
version = ".".join((major, minor, patch))
|
|
|
|
if extra:
|
|
|
|
version += "-" + extra
|
2015-05-13 20:05:30 +02:00
|
|
|
|
2021-07-22 16:14:51 +02:00
|
|
|
release = version
|
|
|
|
|
2024-01-15 19:04:47 +01:00
|
|
|
# parse SDK version from 'SDK_VERSION' file
|
|
|
|
with open(ZEPHYR_BASE / "SDK_VERSION") as f:
|
|
|
|
sdk_version = f.read().strip()
|
|
|
|
|
2021-03-30 13:09:11 +02:00
|
|
|
# -- General configuration ------------------------------------------------
|
|
|
|
|
|
|
|
extensions = [
|
2023-08-09 17:52:13 +02:00
|
|
|
"breathe",
|
2023-12-04 15:54:13 +01:00
|
|
|
"sphinx_rtd_theme",
|
2021-03-30 14:50:25 +02:00
|
|
|
"sphinx.ext.todo",
|
|
|
|
"sphinx.ext.extlinks",
|
|
|
|
"sphinx.ext.autodoc",
|
2021-07-20 16:12:23 +02:00
|
|
|
"sphinx.ext.graphviz",
|
2023-07-12 20:47:14 +02:00
|
|
|
"sphinxcontrib.jquery",
|
2021-03-30 14:50:25 +02:00
|
|
|
"zephyr.application",
|
|
|
|
"zephyr.html_redirects",
|
2022-01-12 13:41:15 +01:00
|
|
|
"zephyr.kconfig",
|
2021-03-30 14:50:25 +02:00
|
|
|
"zephyr.dtcompatible-role",
|
|
|
|
"zephyr.link-roles",
|
|
|
|
"sphinx_tabs.tabs",
|
2024-02-26 11:59:57 +01:00
|
|
|
"sphinx_sitemap",
|
2021-04-06 00:02:03 +02:00
|
|
|
"zephyr.warnings_filter",
|
2021-04-16 10:47:43 +02:00
|
|
|
"zephyr.doxyrunner",
|
2023-10-25 12:12:02 +02:00
|
|
|
"zephyr.gh_utils",
|
2023-08-31 14:59:14 +02:00
|
|
|
"zephyr.manifest_projects_table",
|
2021-05-19 16:04:20 +02:00
|
|
|
"notfound.extension",
|
2022-03-25 13:29:37 +01:00
|
|
|
"sphinx_copybutton",
|
2023-08-30 09:26:48 +02:00
|
|
|
"sphinx_togglebutton",
|
2021-05-10 19:11:14 +02:00
|
|
|
"zephyr.external_content",
|
2023-08-30 08:46:55 +02:00
|
|
|
"zephyr.domain",
|
2023-08-25 22:58:52 +02:00
|
|
|
"zephyr.api_overview",
|
2021-03-30 13:09:11 +02:00
|
|
|
]
|
|
|
|
|
|
|
|
# Only use SVG converter when it is really needed, e.g. LaTeX.
|
|
|
|
if tags.has("svgconvert"): # pylint: disable=undefined-variable
|
2021-03-30 14:50:25 +02:00
|
|
|
extensions.append("sphinxcontrib.rsvgconverter")
|
2021-03-30 13:09:11 +02:00
|
|
|
|
2021-03-30 14:50:25 +02:00
|
|
|
templates_path = ["_templates"]
|
2021-03-30 13:09:11 +02:00
|
|
|
|
2021-03-30 14:50:25 +02:00
|
|
|
exclude_patterns = ["_build"]
|
2015-05-13 20:05:30 +02:00
|
|
|
|
2018-11-12 16:14:51 +01:00
|
|
|
if not west_found:
|
2021-03-30 14:50:25 +02:00
|
|
|
exclude_patterns.append("**/*west-apis*")
|
2018-11-12 16:14:51 +01:00
|
|
|
else:
|
2021-03-30 14:50:25 +02:00
|
|
|
exclude_patterns.append("**/*west-not-found*")
|
2015-05-13 20:05:30 +02:00
|
|
|
|
2021-03-30 14:50:25 +02:00
|
|
|
pygments_style = "sphinx"
|
2023-10-20 18:46:25 +02:00
|
|
|
highlight_language = "none"
|
2015-05-13 20:05:30 +02:00
|
|
|
|
2015-08-07 19:22:27 +02:00
|
|
|
todo_include_todos = False
|
2015-06-12 19:51:09 +02:00
|
|
|
|
2022-02-02 11:14:26 +01:00
|
|
|
nitpick_ignore = [
|
|
|
|
# ignore C standard identifiers (they are not defined in Zephyr docs)
|
|
|
|
("c:identifier", "FILE"),
|
|
|
|
("c:identifier", "int8_t"),
|
|
|
|
("c:identifier", "int16_t"),
|
|
|
|
("c:identifier", "int32_t"),
|
|
|
|
("c:identifier", "int64_t"),
|
|
|
|
("c:identifier", "intptr_t"),
|
|
|
|
("c:identifier", "off_t"),
|
|
|
|
("c:identifier", "size_t"),
|
|
|
|
("c:identifier", "ssize_t"),
|
|
|
|
("c:identifier", "time_t"),
|
|
|
|
("c:identifier", "uint8_t"),
|
|
|
|
("c:identifier", "uint16_t"),
|
|
|
|
("c:identifier", "uint32_t"),
|
|
|
|
("c:identifier", "uint64_t"),
|
|
|
|
("c:identifier", "uintptr_t"),
|
|
|
|
("c:identifier", "va_list"),
|
|
|
|
]
|
|
|
|
|
2024-01-15 19:04:47 +01:00
|
|
|
SDK_URL_BASE="https://github.com/zephyrproject-rtos/sdk-ng/releases/download"
|
|
|
|
|
|
|
|
rst_epilog = f"""
|
2018-05-05 01:31:05 +02:00
|
|
|
.. include:: /substitutions.txt
|
2024-01-15 19:04:47 +01:00
|
|
|
|
|
|
|
.. |sdk-version-literal| replace:: ``{sdk_version}``
|
|
|
|
.. |sdk-version-trim| unicode:: {sdk_version}
|
|
|
|
:trim:
|
|
|
|
.. |sdk-version-ltrim| unicode:: {sdk_version}
|
|
|
|
:ltrim:
|
|
|
|
.. _Zephyr SDK bundle: https://github.com/zephyrproject-rtos/sdk-ng/releases/tag/v{sdk_version}
|
|
|
|
.. |sdk-url-linux| replace:: `{SDK_URL_BASE}/v{sdk_version}/zephyr-sdk-{sdk_version}_linux-x86_64.tar.xz`
|
|
|
|
.. |sdk-url-linux-sha| replace:: `{SDK_URL_BASE}/v{sdk_version}/sha256.sum`
|
|
|
|
.. |sdk-url-macos| replace:: `{SDK_URL_BASE}/v{sdk_version}/zephyr-sdk-{sdk_version}_macos-x86_64.tar.xz`
|
|
|
|
.. |sdk-url-macos-sha| replace:: `{SDK_URL_BASE}/v{sdk_version}/sha256.sum`
|
|
|
|
.. |sdk-url-windows| replace:: `{SDK_URL_BASE}/v{sdk_version}/zephyr-sdk-{sdk_version}_windows-x86_64.7z`
|
2015-06-12 19:51:09 +02:00
|
|
|
"""
|
2015-05-13 20:05:30 +02:00
|
|
|
|
|
|
|
# -- Options for HTML output ----------------------------------------------
|
|
|
|
|
2018-08-04 01:12:03 +02:00
|
|
|
html_theme = "sphinx_rtd_theme"
|
2021-05-17 19:22:17 +02:00
|
|
|
html_theme_options = {
|
|
|
|
"logo_only": True,
|
|
|
|
"prev_next_buttons_location": None
|
|
|
|
}
|
2023-02-13 14:47:56 +01:00
|
|
|
html_baseurl = "https://docs.zephyrproject.org/latest/"
|
2015-06-29 21:33:28 +02:00
|
|
|
html_title = "Zephyr Project Documentation"
|
2021-05-19 12:25:16 +02:00
|
|
|
html_logo = str(ZEPHYR_BASE / "doc" / "_static" / "images" / "logo.svg")
|
2021-06-30 15:03:11 +02:00
|
|
|
html_favicon = str(ZEPHYR_BASE / "doc" / "_static" / "images" / "favicon.png")
|
2021-03-30 14:50:25 +02:00
|
|
|
html_static_path = [str(ZEPHYR_BASE / "doc" / "_static")]
|
|
|
|
html_last_updated_fmt = "%b %d, %Y"
|
2015-08-07 19:22:27 +02:00
|
|
|
html_domain_indices = False
|
|
|
|
html_split_index = True
|
2018-07-31 22:47:10 +02:00
|
|
|
html_show_sourcelink = False
|
2015-10-16 16:30:15 +02:00
|
|
|
html_show_sphinx = False
|
2021-05-19 12:25:16 +02:00
|
|
|
html_search_scorer = str(ZEPHYR_BASE / "doc" / "_static" / "js" / "scorer.js")
|
2023-11-07 11:32:08 +01:00
|
|
|
html_additional_pages = {
|
|
|
|
"gsearch": "gsearch.html"
|
|
|
|
}
|
2015-05-13 20:05:30 +02:00
|
|
|
|
2021-03-30 14:50:25 +02:00
|
|
|
is_release = tags.has("release") # pylint: disable=undefined-variable
|
2021-10-28 18:57:20 +02:00
|
|
|
reference_prefix = ""
|
|
|
|
if tags.has("publish"): # pylint: disable=undefined-variable
|
|
|
|
reference_prefix = f"/{version}" if is_release else "/latest"
|
2021-03-30 14:50:25 +02:00
|
|
|
docs_title = "Docs / {}".format(version if is_release else "Latest")
|
2021-03-30 13:09:11 +02:00
|
|
|
html_context = {
|
2021-03-30 14:50:25 +02:00
|
|
|
"show_license": True,
|
|
|
|
"docs_title": docs_title,
|
|
|
|
"is_release": is_release,
|
|
|
|
"current_version": version,
|
|
|
|
"versions": (
|
|
|
|
("latest", "/"),
|
2024-02-23 18:29:16 +01:00
|
|
|
("3.6.0", "/3.6.0/"),
|
2023-10-20 08:42:16 +02:00
|
|
|
("3.5.0", "/3.5.0/"),
|
2024-03-02 00:10:23 +01:00
|
|
|
("2.7.6 (LTS)", "/2.7.6/"),
|
2021-03-30 14:50:25 +02:00
|
|
|
),
|
2023-10-25 12:12:02 +02:00
|
|
|
"display_gh_links": True,
|
2021-10-28 18:57:20 +02:00
|
|
|
"reference_links": {
|
|
|
|
"API": f"{reference_prefix}/doxygen/html/index.html",
|
2022-01-12 13:41:15 +01:00
|
|
|
"Kconfig Options": f"{reference_prefix}/kconfig.html",
|
2022-04-05 16:17:26 +02:00
|
|
|
"Devicetree Bindings": f"{reference_prefix}/build/dts/api/bindings.html",
|
2023-10-02 13:48:32 +02:00
|
|
|
"West Projects": f"{reference_prefix}/develop/manifest/index.html",
|
2023-07-04 17:20:09 +02:00
|
|
|
},
|
|
|
|
# Set google_searchengine_id to your Search Engine ID to replace built-in search
|
|
|
|
# engine with Google's Programmable Search Engine.
|
|
|
|
# See https://programmablesearchengine.google.com/ for details.
|
|
|
|
"google_searchengine_id": "746031aa0d56d4912",
|
2021-03-30 13:09:11 +02:00
|
|
|
}
|
2019-01-20 14:56:48 +01:00
|
|
|
|
2015-05-13 20:05:30 +02:00
|
|
|
# -- Options for LaTeX output ---------------------------------------------
|
|
|
|
|
|
|
|
latex_elements = {
|
2021-07-22 16:14:51 +02:00
|
|
|
"papersize": "a4paper",
|
|
|
|
"maketitle": open(ZEPHYR_BASE / "doc" / "_static" / "latex" / "title.tex").read(),
|
|
|
|
"preamble": open(ZEPHYR_BASE / "doc" / "_static" / "latex" / "preamble.tex").read(),
|
2023-11-06 12:39:57 +01:00
|
|
|
"makeindex": r"\usepackage[columns=1]{idxlayout}\makeindex",
|
2023-10-19 18:46:47 +02:00
|
|
|
"fontpkg": textwrap.dedent(r"""
|
|
|
|
\usepackage{noto}
|
|
|
|
\usepackage{inconsolata-nerd-font}
|
|
|
|
\usepackage[T1]{fontenc}
|
|
|
|
"""),
|
2021-07-22 16:14:51 +02:00
|
|
|
"sphinxsetup": ",".join(
|
|
|
|
(
|
|
|
|
# NOTE: colors match those found in light.css stylesheet
|
|
|
|
"verbatimwithframe=false",
|
|
|
|
"VerbatimColor={HTML}{f0f2f4}",
|
|
|
|
"InnerLinkColor={HTML}{2980b9}",
|
|
|
|
"warningBgColor={HTML}{e9a499}",
|
|
|
|
"warningborder=0pt",
|
|
|
|
r"HeaderFamily=\rmfamily\bfseries",
|
|
|
|
)
|
|
|
|
),
|
2015-05-13 20:05:30 +02:00
|
|
|
}
|
2021-07-22 16:14:51 +02:00
|
|
|
latex_logo = str(ZEPHYR_BASE / "doc" / "_static" / "images" / "logo-latex.pdf")
|
2015-05-13 20:05:30 +02:00
|
|
|
latex_documents = [
|
2021-07-22 16:14:51 +02:00
|
|
|
("index-tex", "zephyr.tex", "Zephyr Project Documentation", author, "manual"),
|
2015-05-13 20:05:30 +02:00
|
|
|
]
|
2023-10-19 18:42:53 +02:00
|
|
|
latex_engine = "xelatex"
|
2015-05-13 20:05:30 +02:00
|
|
|
|
2021-04-16 10:47:43 +02:00
|
|
|
# -- Options for zephyr.doxyrunner plugin ---------------------------------
|
|
|
|
|
|
|
|
doxyrunner_doxygen = os.environ.get("DOXYGEN_EXECUTABLE", "doxygen")
|
|
|
|
doxyrunner_doxyfile = ZEPHYR_BASE / "doc" / "zephyr.doxyfile.in"
|
|
|
|
doxyrunner_outdir = ZEPHYR_BUILD / "doxygen"
|
|
|
|
doxyrunner_fmt = True
|
2021-10-03 19:32:42 +02:00
|
|
|
doxyrunner_fmt_vars = {"ZEPHYR_BASE": str(ZEPHYR_BASE), "ZEPHYR_VERSION": version}
|
2022-01-10 12:35:31 +01:00
|
|
|
doxyrunner_outdir_var = "DOXY_OUT"
|
2021-04-16 10:47:43 +02:00
|
|
|
|
2023-08-09 17:52:13 +02:00
|
|
|
# -- Options for Breathe plugin -------------------------------------------
|
2021-03-30 13:09:11 +02:00
|
|
|
|
2023-08-09 17:52:13 +02:00
|
|
|
breathe_projects = {"Zephyr": str(doxyrunner_outdir / "xml")}
|
|
|
|
breathe_default_project = "Zephyr"
|
|
|
|
breathe_domain_by_extension = {
|
2020-05-18 22:46:26 +02:00
|
|
|
"h": "c",
|
|
|
|
"c": "c",
|
|
|
|
}
|
2023-08-09 17:52:13 +02:00
|
|
|
breathe_show_enumvalue_initializer = True
|
|
|
|
breathe_default_members = ("members", )
|
2019-03-12 23:39:09 +01:00
|
|
|
|
2020-06-01 13:57:27 +02:00
|
|
|
cpp_id_attributes = [
|
2021-03-30 14:50:25 +02:00
|
|
|
"__syscall",
|
2023-04-20 17:04:55 +02:00
|
|
|
"__syscall_always_inline",
|
2021-03-30 14:50:25 +02:00
|
|
|
"__deprecated",
|
|
|
|
"__may_alias",
|
|
|
|
"__used",
|
|
|
|
"__unused",
|
|
|
|
"__weak",
|
2021-04-09 06:40:41 +02:00
|
|
|
"__attribute_const__",
|
2021-03-30 14:50:25 +02:00
|
|
|
"__DEPRECATED_MACRO",
|
|
|
|
"FUNC_NORETURN",
|
|
|
|
"__subsystem",
|
2022-02-01 21:30:19 +01:00
|
|
|
"ALWAYS_INLINE",
|
2020-06-01 13:57:27 +02:00
|
|
|
]
|
|
|
|
c_id_attributes = cpp_id_attributes
|
2017-09-29 20:31:46 +02:00
|
|
|
|
2021-03-30 13:09:11 +02:00
|
|
|
# -- Options for html_redirect plugin -------------------------------------
|
2021-03-30 12:18:02 +02:00
|
|
|
|
2021-03-30 13:09:11 +02:00
|
|
|
html_redirect_pages = redirects.REDIRECTS
|
2017-01-03 20:43:02 +01:00
|
|
|
|
2021-04-06 00:02:03 +02:00
|
|
|
# -- Options for zephyr.warnings_filter -----------------------------------
|
|
|
|
|
|
|
|
warnings_filter_config = str(ZEPHYR_BASE / "doc" / "known-warnings.txt")
|
|
|
|
|
2022-10-12 15:29:10 +02:00
|
|
|
# -- Options for zephyr.link-roles ----------------------------------------
|
|
|
|
|
|
|
|
link_roles_manifest_project = "zephyr"
|
|
|
|
link_roles_manifest_baseurl = "https://github.com/zephyrproject-rtos/zephyr"
|
|
|
|
|
2021-05-19 16:04:20 +02:00
|
|
|
# -- Options for notfound.extension ---------------------------------------
|
|
|
|
|
2021-06-22 11:16:25 +02:00
|
|
|
notfound_urls_prefix = f"/{version}/" if is_release else "/latest/"
|
2021-05-19 16:04:20 +02:00
|
|
|
|
2023-10-25 12:12:02 +02:00
|
|
|
# -- Options for zephyr.gh_utils ------------------------------------------
|
2021-06-28 20:08:13 +02:00
|
|
|
|
2023-10-25 12:12:02 +02:00
|
|
|
gh_link_version = f"v{version}" if is_release else "main"
|
|
|
|
gh_link_base_url = f"https://github.com/zephyrproject-rtos/zephyr"
|
|
|
|
gh_link_prefixes = {
|
2021-06-28 20:08:13 +02:00
|
|
|
"samples/.*": "",
|
|
|
|
"boards/.*": "",
|
2023-01-10 00:46:59 +01:00
|
|
|
"snippets/.*": "",
|
2021-06-28 20:08:13 +02:00
|
|
|
".*": "doc",
|
|
|
|
}
|
2023-10-25 12:12:02 +02:00
|
|
|
gh_link_exclude = [
|
2021-06-28 20:08:13 +02:00
|
|
|
"reference/kconfig.*",
|
2022-04-05 16:17:26 +02:00
|
|
|
"build/dts/api/bindings.*",
|
|
|
|
"build/dts/api/compatibles.*",
|
2021-06-28 20:08:13 +02:00
|
|
|
]
|
|
|
|
|
2022-01-12 13:41:15 +01:00
|
|
|
# -- Options for zephyr.kconfig -------------------------------------------
|
|
|
|
|
|
|
|
kconfig_generate_db = True
|
|
|
|
kconfig_ext_paths = [ZEPHYR_BASE]
|
|
|
|
|
2021-05-10 19:11:14 +02:00
|
|
|
# -- Options for zephyr.external_content ----------------------------------
|
|
|
|
|
|
|
|
external_content_contents = [
|
|
|
|
(ZEPHYR_BASE / "doc", "[!_]*"),
|
|
|
|
(ZEPHYR_BASE, "boards/**/*.rst"),
|
|
|
|
(ZEPHYR_BASE, "boards/**/doc"),
|
2023-09-08 12:01:57 +02:00
|
|
|
(ZEPHYR_BASE, "samples/**/*.html"),
|
2021-05-10 19:11:14 +02:00
|
|
|
(ZEPHYR_BASE, "samples/**/*.rst"),
|
|
|
|
(ZEPHYR_BASE, "samples/**/doc"),
|
2023-01-10 00:46:59 +01:00
|
|
|
(ZEPHYR_BASE, "snippets/**/*.rst"),
|
|
|
|
(ZEPHYR_BASE, "snippets/**/doc"),
|
2021-05-10 19:11:14 +02:00
|
|
|
]
|
|
|
|
external_content_keep = [
|
|
|
|
"reference/kconfig/*",
|
2023-08-31 14:59:14 +02:00
|
|
|
"develop/manifest/index.rst",
|
2022-04-05 16:17:26 +02:00
|
|
|
"build/dts/api/bindings.rst",
|
|
|
|
"build/dts/api/bindings/**/*",
|
|
|
|
"build/dts/api/compatibles/**/*",
|
2021-05-10 19:11:14 +02:00
|
|
|
]
|
|
|
|
|
2024-01-09 15:34:14 +01:00
|
|
|
# -- Options for zephyr.domain --------------------------------------------
|
|
|
|
|
|
|
|
zephyr_breathe_insert_related_samples = True
|
|
|
|
|
2021-07-20 16:12:23 +02:00
|
|
|
# -- Options for sphinx.ext.graphviz --------------------------------------
|
|
|
|
|
|
|
|
graphviz_dot = os.environ.get("DOT_EXECUTABLE", "dot")
|
|
|
|
graphviz_output_format = "svg"
|
|
|
|
graphviz_dot_args = [
|
|
|
|
"-Gbgcolor=transparent",
|
|
|
|
"-Nstyle=filled",
|
|
|
|
"-Nfillcolor=white",
|
|
|
|
"-Ncolor=gray60",
|
|
|
|
"-Nfontcolor=gray25",
|
|
|
|
"-Ecolor=gray60",
|
|
|
|
]
|
|
|
|
|
2023-10-18 04:38:31 +02:00
|
|
|
# -- Options for sphinx_copybutton ----------------------------------------
|
|
|
|
|
|
|
|
copybutton_prompt_text = r"\$ |uart:~\$ "
|
|
|
|
copybutton_prompt_is_regexp = True
|
|
|
|
|
2024-02-26 11:59:57 +01:00
|
|
|
# -- Options for sphinx-sitemap ----------------------------------------
|
|
|
|
|
|
|
|
sitemap_url_scheme = "{link}"
|
|
|
|
|
2021-03-30 13:09:11 +02:00
|
|
|
# -- Linkcheck options ----------------------------------------------------
|
2019-01-20 14:56:48 +01:00
|
|
|
|
2023-10-18 14:23:55 +02:00
|
|
|
linkcheck_ignore = [
|
|
|
|
r"https://github.com/zephyrproject-rtos/zephyr/issues/.*"
|
|
|
|
]
|
|
|
|
|
2021-03-30 14:50:25 +02:00
|
|
|
extlinks = {
|
2022-08-11 18:01:47 +02:00
|
|
|
"github": ("https://github.com/zephyrproject-rtos/zephyr/issues/%s", "GitHub #%s"),
|
2021-03-30 14:50:25 +02:00
|
|
|
}
|
2017-04-27 23:59:04 +02:00
|
|
|
|
|
|
|
linkcheck_timeout = 30
|
|
|
|
linkcheck_workers = 10
|
|
|
|
linkcheck_anchors = False
|
|
|
|
|
2023-08-25 22:58:52 +02:00
|
|
|
# -- Options for zephyr.api_overview --------------------------------------
|
|
|
|
|
|
|
|
api_overview_doxygen_base_url = "../../doxygen/html"
|
2021-03-30 14:50:25 +02:00
|
|
|
|
2017-01-28 01:20:21 +01:00
|
|
|
def setup(app):
|
2021-03-12 14:33:16 +01:00
|
|
|
# theme customizations
|
|
|
|
app.add_css_file("css/custom.css")
|
2023-12-05 15:17:47 +01:00
|
|
|
app.add_js_file("js/custom.js")
|
2021-03-12 14:33:16 +01:00
|
|
|
app.add_js_file("js/dark-mode-toggle.min.mjs", type="module")
|