Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/j-sephb-lt-n/python-auto-documentation-with-mkdocstrings
An illustration of automatic project documentation using mkdocs
https://github.com/j-sephb-lt-n/python-auto-documentation-with-mkdocstrings
documentation github-actions mkdocs mkdocs-material mkdocstrings python
Last synced: 13 days ago
JSON representation
An illustration of automatic project documentation using mkdocs
- Host: GitHub
- URL: https://github.com/j-sephb-lt-n/python-auto-documentation-with-mkdocstrings
- Owner: J-sephB-lt-n
- License: gpl-3.0
- Created: 2023-11-20T18:45:52.000Z (about 1 year ago)
- Default Branch: main
- Last Pushed: 2023-11-21T20:28:39.000Z (about 1 year ago)
- Last Synced: 2024-11-07T10:19:57.836Z (2 months ago)
- Topics: documentation, github-actions, mkdocs, mkdocs-material, mkdocstrings, python
- Language: Python
- Homepage:
- Size: 585 KB
- Stars: 0
- Watchers: 1
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Auto-Generated Python Project Documentation with MkDocs
This repo is my investigation of automatic python project documentation using [MkDocs](https://github.com/mkdocs/mkdocs), [MkDocStrings](https://github.com/mkdocstrings/mkdocstrings) and [Material for MkDocs](https://github.com/squidfunk/mkdocs-material). The documentation is then hosted on [GitHub pages](https://pages.github.com), with automatic deployment using [GitHub Actions](https://docs.github.com/en/actions).
The structure of this repo is from the [Real Python](https://realpython.com) tutorial [Build Your Python Project Documentation With MkDocs](https://realpython.com/python-project-documentation-with-mkdocs/).
You can browse the static build of the documentation here: https://J-sephB-lt-n.github.io/python-auto-documentation-with-mkdocstrings/
# Instructions/Explanation of the Documentation Process
* Refer to [requirements.txt](./requirements.txt) for the required packages.
* The initial MkDocs files were created by running
mkdocs new .
in terminal from the root project directory. This command creates the files [makedocs.yml](./makedocs.yml) and [/docs/index.md](./docs/index.md).* [makedocs.yml](./makedocs.yml) contains settings controlling the documentation style and behaviour.
* This code in [makedocs.yml](./makedocs.yml) enables the documentation to automatically extract information from the docstrings in the code itself:
```yaml
plugins:
- mkdocstrings
```* In order to specify which docstrings should be included in the documentation, add links into the markdown using the triple-colon format e.g.
::: link.to.python.module
* The documentation is built by combining and rendering the markdown files in the [/docs/](./docs/) folder.
* The documentation can be hosted locally by running
mkdocs serve
in terminal from the root project directory (view the documentation in the browser by going to the localhost URL specified - it will be something like http://localhost:8000).* The documentation can be rendered into static html using the terminal command
mkdocs build
. The output is written to the folder [/site/](./site/), which should be added to the [.gitignore](./.gitignore) file.* If the project code is already inside a GitHub repository, the documentation can be hosted (for free) on GitHub pages (at the url https://your-user-name.github.io/your-repo-name/) by running the terminal command
mkdocs gh-deploy
.# Automatic GitHub Deployment of Documentation
Adding the yaml file [.github/workflows/deploy_documentation.yml](./.github/workflows/deploy_documentation.yml) causes the documentation to be automatically deployed (i.e. runs the code
mkdocs gh-deploy
) whenever there is a push to the main branch of this repo.Note also that for this process to work, you need to give GitHub actions "Read and Write permissions" on this repo. I did this using the GitHub website GUI - the setting is available under Settings->Actions->General.
# References
* https://realpython.com/python-project-documentation-with-mkdocs/
* https://numpydoc.readthedocs.io/en/latest
* https://blog.elmah.io/deploying-a-mkdocs-documentation-site-with-github-actions/