autodoc-traits1.2.2
Published
Sphinx extension to autodoc traitlets
pip install autodoc-traits
Package Downloads
Authors
Project URLs
Requires Python
>=3.7
Dependencies
autodoc-traits
autodoc-traits is a Sphinx extension that builds on sphinx.ext.autodoc
to better document classes with Traitlets based configuration.
autodoc-traits provides the Sphinx directives autoconfigurable (use with
classes) and autotrait (use with the traitlets based configuration options).
The sphinx.ext.autodoc provided directive [automodule][], which can overview
classes, will with autodoc-traits enabled use autoconfigurable over
autoclass for classes has trait based configuration. Similarly, the
sphinx.ext.autodoc provided autoclass directive will use autotrait over
autoattribute if configured to present the traitlets attributes normally
not presented.
The autoattribute directive will provide a header looking like trait c.SampleConfigurable.trait = Bool(False), and as docstring it will use the
trait's configured help text.
How to use it
-
Install
autodoc-traits:pip install autodoc-traits -
Configure Sphinx to use the
autodoc_traitsextensions in a Sphinx project'sconf.pyfile:# -- General Sphinx configuration -------------------------------------------- # ref: https://www.sphinx-doc.org/en/master/usage/configuration.html#general-configuration # extensions = [ "autodoc_traits", # sphinx.ext.autodoc will be registered by autodoc_traits, # but can safely be registered again. # ... ] -
Make use of the
sphinx.ext.autodocSphinx directive likeautomodulethat document classes, theautodoc_traitsprovidedautoconfigurablethat documents traitlets configurable classes, or theautodoc_traitsprovidedautotraitthat documents individual traitlets configuration options:From a .rst document:
.. automodule:: sample_module :members: .. autoconfigurable:: sample_module.SampleConfigurable .. autotrait:: sample_module.SampleConfigurable.trait
Use with MyST Parser
While you can use myst-parser, sphinx.ext.autodoc's directives emits
unparsed rST, forcing us to parse the autodoc directives in a rST context.
From a .md document, with myst-parser:
```{eval-rst}
.. autoconfigurable:: sample_module.SampleConfigurable
```
Due to this, also the Python docstrings are required to be in rST as well. Addressing this can be tracked from executablebooks/team-compass issue #6.