Configuring Python projects in documenteer.toml#
If you are documenting a Python project that uses pyproject.toml (or setup.cfg and setup.py in legacy situations) to define its project metadata, you can re-use that metadata in your Sphinx configuration rather than repeating it in documenteer.toml by adding a project.python table
Walkthrough#
This is a minimal documenteer.toml file for this project (Documenteer), where the Python package name is documenteer:
[project]
title = "Documenteer"
copyright = "2015-2022 Association of Universities for Research in Astronomy, Inc. (AURA)"
[project.python]
package = "documenteer"
The key content from pyproject.toml looks like this:
[project]
name = "documenteer"
# ...
[project.urls]
Homepage = "https://documenteer.lsst.io"
Source = "https://github.com/lsst-sqre/documenteer"
Notice how the [project] table in documenteer.toml is quite short because most information is found from the Python project metadata:
- versionis inferred from the installed package’s metadata. If you use setuptools_scm, the version automatically increments with every commit or tag.
- base_urlis inferred from the- Homepagefield in- [project.urls]in- pyproject.toml.
- github_urlis inferred from the- Sourcefield in- [project.urls]in- pyproject.toml.
Overriding Python packaging metadata#
You can always override the metadata from pyproject.toml by setting fields explicitly in the [project] table.
For example, to fix the version as “1.0.0”:
[project]
title = "Documenteer"
copyright = "2015-2022 Association of Universities for Research in Astronomy, Inc. (AURA)"
version = "1.0.0"
[project.python]
package = "documenteer"
Using alternative labels in pyproject.toml’s [project.urls]#
Documenteer defaults to Homepage and Source as the labels for the documentation and GitHub homepages, respectively, in [project.urls] table of pyproject.toml.
You can change these defaults in documenteer.toml:
[project]
title = "Documenteer"
copyright = "2015-2022 Association of Universities for Research in Astronomy, Inc. (AURA)"
[project.python]
package = "documenteer"
documentation_url_key = "Docs"
github_url_key = "Repository"
And the corresponding pyproject.toml using those labels:
[project]
name = "documenteer"
# ...
[project.urls]
Docs = "https://documenteer.lsst.io"
Repository = "https://github.com/lsst-sqre/documenteer"