12/07/2024 10:57, Juraj Linkeš: > The tool used to generate DTS API docs is Sphinx, which is already in > use in DPDK. The same configuration is used to preserve style with one > DTS-specific configuration (so that the DPDK docs are unchanged) that > modifies how the sidebar displays the content.
What is changed in the sidebar? > --- a/doc/api/doxy-api-index.md > +++ b/doc/api/doxy-api-index.md > @@ -244,3 +244,6 @@ The public API headers are grouped by topics: > [experimental APIs](@ref rte_compat.h), > [ABI versioning](@ref rte_function_versioning.h), > [version](@ref rte_version.h) > + > +- **tests**: > + [**DTS**](@dts_api_main_page) OK looks good > --- a/doc/api/doxy-api.conf.in > +++ b/doc/api/doxy-api.conf.in > @@ -124,6 +124,8 @@ SEARCHENGINE = YES > SORT_MEMBER_DOCS = NO > SOURCE_BROWSER = YES > > +ALIASES = "dts_api_main_page=@DTS_API_MAIN_PAGE@" Why is it needed? That's the only way to reference it in doxy-api-index.md? Would be nice to explain in the commit log. > --- a/doc/api/meson.build > +++ b/doc/api/meson.build > +# A local reference must be relative to the main index.html page > +# The path below can't be taken from the DTS meson file as that would > +# require recursive subdir traversal (doc, dts, then doc again) This comment is really obscure. > +cdata.set('DTS_API_MAIN_PAGE', join_paths('..', 'dts', 'html', 'index.html')) Oh I think I get it: - DTS_API_MAIN_PAGE is the Meson variable - dts_api_main_page is the Doxygen variable > +# Napoleon enables the Google format of Python doscstrings, used in DTS > +# Intersphinx allows linking to external projects, such as Python docs, also > used in DTS Close sentences with a dot, it is easier to read. > +extensions = ['sphinx.ext.napoleon', 'sphinx.ext.intersphinx'] > + > +# DTS Python docstring options > +autodoc_default_options = { > + 'members': True, > + 'member-order': 'bysource', > + 'show-inheritance': True, > +} > +autodoc_class_signature = 'separated' > +autodoc_typehints = 'both' > +autodoc_typehints_format = 'short' > +autodoc_typehints_description_target = 'documented' > +napoleon_numpy_docstring = False > +napoleon_attr_annotations = True > +napoleon_preprocess_types = True > +add_module_names = False > +toc_object_entries = True > +toc_object_entries_show_parents = 'hide' > +intersphinx_mapping = {'python': ('https://docs.python.org/3', None)} > + > +dts_root = environ.get('DTS_ROOT') Why does it need to be passed as an environment variable? Isn't it a fixed absolute path? > +if dts_root: > + path.append(dts_root) > + # DTS Sidebar config > + html_theme_options = { > + 'collapse_navigation': False, > + 'navigation_depth': -1, > + } [...] > +To build DTS API docs, install the dependencies with Poetry, then enter its > shell: I don't plan to use Poetry on my machine. Can we simply describe the dependencies even if the versions are not specified? > + > +.. code-block:: console > + > + poetry install --no-root --with docs > + poetry shell > + > +The documentation is built using the standard DPDK build system. > +After executing the meson command and entering Poetry's shell, build the > documentation with: > + > +.. code-block:: console > + > + ninja -C build dts-doc Don't we rely on the Meson option "enable_docs"? > + > +The output is generated in ``build/doc/api/dts/html``. > + > +.. Note:: In general the RST expressions are lowercase. > + > + Make sure to fix any Sphinx warnings when adding or updating docstrings, > + and also run the ``devtools/dts-check-format.sh`` script and address any > issues it finds. It looks like something to write in the contributing guide. > +++ b/dts/doc/meson.build > @@ -0,0 +1,27 @@ > +# SPDX-License-Identifier: BSD-3-Clause > +# Copyright(c) 2023 PANTHEON.tech s.r.o. > + > +sphinx = find_program('sphinx-build', required: false) > +sphinx_apidoc = find_program('sphinx-apidoc', required: false) > + > +if not sphinx.found() or not sphinx_apidoc.found() You should include the option "enable_docs" here. > + subdir_done() > +endif