Documentation directory layout¶
Cloud-init’s documentation directory structure, with respect to the root directory:
/doc/
- examples/
- man/
- module-docs/
- rtd/
- tutorial/
- howto/
- explanation/
- reference/
- development/
- static/
- css/
- js/
- *logos*
- *conf.py*
- *index.rst*
- *links.txt*
- rtd_html/
- sources/
examples/¶
man/¶
This subdirectory contains the Linux man pages for the binaries provided by cloud-init.
module-docs/¶
The documentation for modules is generated automatically using YAML files and templates. Each module has its own sub-directory, containing:
data.yaml
file: Contains the text and descriptions rendered on the modules documentation page.example*.yaml
files: These examples stand alone as valid cloud-config. They always start with#cloud-config
, and ideally, should also have some accompanying discussion or context in thecomment
field in thedata.yaml
file to explain what’s happening.
Edit existing module docs¶
In the data.yaml
file, the fields support reStructuredText markup in the
description
and comment
fields. With the pipe character (|
)
preceding these fields, the text will be preserved so that using rST directives
(such as notes or code blocks) will render correctly in the documentation. If
you don’t need to use directives, you can use the greater-than character
(>
), which will fold broken lines together into paragraphs (while
respecting empty lines).
Create new module docs¶
Creating documentation for a new module involves a little more work, and the process for that is outlined in the contributing modules page.
rtd/
¶
This subdirectory is of most interest to anyone who wants to create or update either the content of the documentation, or the styling of it.
The content of the documentation is organized according to the Diataxis framework and can be found in the subdirectories:
tutorial/
,howto/
,explanation/
, andreference/
.The
development/
subdirectory contains documentation for contributors.static/
contains content that relates to the styling of the documentation in the form of custom CSS or javascript files found incss/
andjs/
respectively. This is also where you can find the cloud-init logo.conf.py
contains Sphinx configuration commands.index.rst
is the front page of the documentation.links.txt
contains common (and reusable) links so that you do not need to define the same URLs on every page and can use a more convenient shorthand when referencing often-used links.
rtd_html/
¶
When the documentation is built locally using tox -e doc
, the built pages
can be found in this folder.
sources/
¶
This subdirectory contains demos which can help the reader understand how parts of the product work.