summaryrefslogtreecommitdiff
path: root/doc/rtd/topics/docs.rst
blob: 1b15377ec9f21de89c615f1f390ed32371f9661e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
.. _docs:

Docs
****

These docs are hosted on Read the Docs. The following will explain how to
contribute to and build these docs locally.

The documentation is primarily written in reStructuredText.


Building
========

There is a makefile target to build the documentation for you:

.. code-block:: shell-session

    $ tox -e doc

This will do two things:

- Build the documentation using sphinx
- Run doc8 against the documentation source code

Once build the HTML files will be viewable in ``doc/rtd_html``. Use your
web browser to open ``index.html`` to view and navigate the site.

Style Guide
===========

Headings
--------
The headings used across the documentation use the following hierarchy:

- ``*****``: used once atop of a new page
- ``=====``: each sections on the page
- ``-----``: subsections
- ``^^^^^``: sub-subsections
- ``"""""``: paragraphs

The top level header ``######`` is reserved for the first page.

If under and overline are used, their length must be identical. The length of
the underline must be at least as long as the title itself

Line Length
-----------
Please keep the line lengths to a maximum of **79** characters. This ensures
that the pages and tables do not get too wide that side scrolling is required.

Header
------
Adding a link at the top of the page allows for the page to be referenced by
other pages. For example for the FAQ page this would be:

.. code-block:: rst

    .. _faq:

Footer
------
The footer should include the textwidth

.. code-block:: rst

    .. vi: textwidth=79

Vertical Whitespace
-------------------
One newline between each section helps ensure readability of the documentation
source code.

Common Words
------------
There are some common words that should follow specific usage:

- ``cloud-init``: always lower case with a hyphen, unless starting a sentence
  in which case only the 'C' is capitalized (e.g. ``Cloud-init``).
- ``metadata``: one word
- ``user data``: two words, not to be combined
- ``vendor data``: like user data, it is two words

.. vi: textwidth=79