doc: add a toctree with reference material
Add a new toctree with reference material, including: - API docs (Doxygen) - Kconfig options - Devicetree bindings Note that the toctree is rendered manually due to the limitations Sphinx has when it comes to including relative URLs. Hardcoding absolute URLs in toctrees is possible, but that means we'd need to update the toctree on every release (to point to /version/ URL), and downstream users of the documentation would have to manually patch the toctree with their own URL. In order to make local builds work, version prefix is only added if publish tag is provided. Signed-off-by: Gerard Marull-Paretas <gerard.marull@nordicsemi.no>
This commit is contained in:
parent
a1e7c4dbfa
commit
b4f968cf9d
4 changed files with 21 additions and 2 deletions
2
.github/workflows/doc-build.yml
vendored
2
.github/workflows/doc-build.yml
vendored
|
@ -73,7 +73,7 @@ jobs:
|
||||||
DOC_TAG="development"
|
DOC_TAG="development"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
DOC_TAG=${DOC_TAG} SPHINXOPTS="-q -W -j auto" make -C doc html
|
DOC_TAG=${DOC_TAG} SPHINXOPTS="-q -W -j auto -t publish" make -C doc html
|
||||||
|
|
||||||
- name: compress-docs
|
- name: compress-docs
|
||||||
run: |
|
run: |
|
||||||
|
|
12
doc/_templates/layout.html
vendored
12
doc/_templates/layout.html
vendored
|
@ -17,6 +17,18 @@
|
||||||
{% block menu %}
|
{% block menu %}
|
||||||
{% include "zversions.html" %}
|
{% include "zversions.html" %}
|
||||||
{{ super() }}
|
{{ super() }}
|
||||||
|
{% if reference_links %}
|
||||||
|
<div class="toctree-wrapper compound">
|
||||||
|
<p class="caption"><span class="caption-text">Reference</span></p>
|
||||||
|
<ul>
|
||||||
|
{% for title, url in reference_links.items() %}
|
||||||
|
<li class="toctree-l1">
|
||||||
|
<a class="reference internal" href="{{ url }}">{{ title }}</a>
|
||||||
|
</li>
|
||||||
|
{% endfor %}
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
{% endif %}
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
{% block extrahead %}
|
{% block extrahead %}
|
||||||
<meta name="color-scheme" content="dark light">
|
<meta name="color-scheme" content="dark light">
|
||||||
|
|
|
@ -135,6 +135,9 @@ html_show_sphinx = False
|
||||||
html_search_scorer = str(ZEPHYR_BASE / "doc" / "_static" / "js" / "scorer.js")
|
html_search_scorer = str(ZEPHYR_BASE / "doc" / "_static" / "js" / "scorer.js")
|
||||||
|
|
||||||
is_release = tags.has("release") # pylint: disable=undefined-variable
|
is_release = tags.has("release") # pylint: disable=undefined-variable
|
||||||
|
reference_prefix = ""
|
||||||
|
if tags.has("publish"): # pylint: disable=undefined-variable
|
||||||
|
reference_prefix = f"/{version}" if is_release else "/latest"
|
||||||
docs_title = "Docs / {}".format(version if is_release else "Latest")
|
docs_title = "Docs / {}".format(version if is_release else "Latest")
|
||||||
html_context = {
|
html_context = {
|
||||||
"show_license": True,
|
"show_license": True,
|
||||||
|
@ -151,6 +154,11 @@ html_context = {
|
||||||
("1.14.1", "/1.14.1/"),
|
("1.14.1", "/1.14.1/"),
|
||||||
),
|
),
|
||||||
"display_vcs_link": True,
|
"display_vcs_link": True,
|
||||||
|
"reference_links": {
|
||||||
|
"API": f"{reference_prefix}/doxygen/html/index.html",
|
||||||
|
"Kconfig Options": f"{reference_prefix}/reference/kconfig/index.html",
|
||||||
|
"Devicetree Bindings": f"{reference_prefix}/reference/devicetree/bindings.html",
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
# -- Options for LaTeX output ---------------------------------------------
|
# -- Options for LaTeX output ---------------------------------------------
|
||||||
|
|
|
@ -117,7 +117,6 @@ Sections
|
||||||
Indices and Tables
|
Indices and Tables
|
||||||
******************
|
******************
|
||||||
|
|
||||||
* :ref:`configuration_options`
|
|
||||||
* :ref:`glossary`
|
* :ref:`glossary`
|
||||||
* :ref:`genindex`
|
* :ref:`genindex`
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue