docs/devel/qapi-code-gen.txt: Update to new rST backend conventions

Update the documentation of QAPI document comment syntax to match
the new rST backend requirements. The principal changes are:
 * whitespace is now significant, and multiline definitions
   must have their second and subsequent lines indented to
   match the first line
 * general rST format markup is permitted, not just the small
   set of markup the old texinfo generator handled. For most
   things (notably bulleted and itemized lists) the old format
   was the same as rST is.
 * Specific things that might trip people up:
   - instead of *bold* and _italic_ rST has **bold** and *italic*
   - lists need a preceding and following blank line
   - a lone literal '*' will need to be backslash-escaped to
     avoid a rST syntax error
 * the old leading '|' for example (literal text) blocks is
   replaced by the standard rST '::' literal block.
 * we support arbitrary levels of sub- and sub-sub-heading, not
   just a main and sub-heading like the old texinfo generator
 * lists can now be nested

Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
Message-Id: <20200925162316.21205-18-peter.maydell@linaro.org>
Reviewed-by: Markus Armbruster <armbru@redhat.com>
[Commit message improved slightly]
Signed-off-by: Markus Armbruster <armbru@redhat.com>
This commit is contained in:
Peter Maydell 2020-09-25 17:23:12 +01:00 committed by Markus Armbruster
parent a27ff0a249
commit 55ec69f8b1
1 changed files with 53 additions and 30 deletions

View File

@ -824,23 +824,37 @@ See below for more on definition documentation.
Free-form documentation may be used to provide additional text and Free-form documentation may be used to provide additional text and
structuring content. structuring content.
==== Headings and subheadings ====
A free-form documentation comment containing a line which starts with
some '=' symbols and then a space defines a section heading:
##
# = This is a top level heading
#
# This is a free-form comment which will go under the
# top level heading.
##
##
# == This is a second level heading
##
A heading line must be the first line of the documentation
comment block.
Section headings must always be correctly nested, so you can only
define a third-level heading inside a second-level heading, and so on.
==== Documentation markup ==== ==== Documentation markup ====
Comment text starting with '=' is a section title: Documentation comments can use most rST markup. In particular,
a '::' literal block can be used for examples:
# = Section title # ::
#
Double the '=' for a subsection title: # Text of the example, may span
# multiple lines
# == Subsection title
Both are only permitted in free-form documentation.
'|' denotes examples:
# | Text of the example, may span
# | multiple lines
'*' starts an itemized list: '*' starts an itemized list:
@ -856,34 +870,33 @@ A decimal number followed by '.' starts a numbered list:
# multiple lines # multiple lines
# 2. Second item # 2. Second item
The actual number doesn't matter. You could even use '*' instead of The actual number doesn't matter.
'2.' for the second item.
Lists can't be nested. Blank lines are currently not supported within Lists of either kind must be preceded and followed by a blank line.
lists. If a list item's text spans multiple lines, then the second and
subsequent lines must be correctly indented to line up with the
first character of the first line.
Additional whitespace between the initial '#' and the comment text is The usual '**strong**', '*emphasised*' and '``literal``' markup should
permitted. be used. If you need a single literal '*' you will need to
backslash-escape it. As an extension beyond the usual rST syntax, you
*foo* and _foo_ are for strong and emphasis styles respectively (they can also use '@foo' to reference a name in the schema; this is
do not work over multiple lines). @foo is used to reference a name in rendered the same way as '``foo``'.
the schema.
Example: Example:
## ##
# = Section # Some text foo with **bold** and *emphasis*
# == Subsection
#
# Some text foo with *strong* and _emphasis_
# 1. with a list # 1. with a list
# 2. like that # 2. like that
# #
# And some code: # And some code:
# | $ echo foo
# | -> do this
# | <- get that
# #
# ::
#
# $ echo foo
# -> do this
# <- get that
## ##
@ -937,6 +950,16 @@ multiline argument descriptions.
A 'Since: x.y.z' tagged section lists the release that introduced the A 'Since: x.y.z' tagged section lists the release that introduced the
definition. definition.
The text of a section can start on a new line, in
which case it must not be indented at all. It can also start
on the same line as the 'Note:', 'Returns:', etc tag. In this
case if it spans multiple lines then second and subsequent
lines must be indented to match the first.
An 'Example' or 'Examples' section is automatically rendered
entirely as literal fixed-width text. In other sections,
the text is formatted, and rST markup can be used.
For example: For example:
## ##