Skip to content

Latest commit

 

History

History
71 lines (50 loc) · 2.67 KB

docs.md

File metadata and controls

71 lines (50 loc) · 2.67 KB

Documentation

There is a docs package which can be built as follows:

nix build .#docs

This produces a static build of the docs and places it in a symlink called result in the same directory.

We can re-use this package as a devshell, relying upon it to provide the necessary dependencies for developing the docs.

--8<-- "nix/packages/docs.nix"

The docs are based on MkDocs and the MkDocs Material theme.

Serve locally

To serve the docs locally run mkdocs serve from the docs directory:

mkdocs serve
INFO    -  Building documentation...
INFO    -  Cleaning site directory
WARNING -  The following pages exist in the docs directory, but are not included in the "nav" configuration:
             - index.md
INFO    -  Documentation built in 0.26 seconds
INFO    -  [16:22:36] Watching paths for changes: 'docs/content', 'mkdocs.yml'
INFO    -  [16:22:36] Serving on http://127.0.0.1:8000/treefmt/

Versioning & Publication

Versioning of the docs is managed through mike.

It is responsible for managing the structure of the gh-pages branch in the repository, which Github Pages is configured to serve from.

!!! note

More information about versioning with [MkDocs Material] and [mike] can be found [here](https://squidfunk.github.io/mkdocs-material/setup/setting-up-versioning/).

There is a github workflow, .github/workflows/gh-pages.yml which is responsible for publishing the docs. It does the following:

  • On merge to main, the docs version main is updated.
  • When a new tag is created of the form v.<major>.<minor>.<patch> a docs version v<major>.<minor> is created and the latest alias is updated to point to this.

The idea is that users will land on the latest released version of the docs by default, with main being available if they wish to read about unreleased features and changes.

To preview the versions locally you can use mike serve instead of mkdocs serve.

!!! warning

Be sure to have fetched the latest changes for the `gh-pages` branch first.
This is especially important if you are using `mike` locally to make manual changes to the published site.