Sphinx Quickstart Template¶
This article is intended to take someone in the state of “I want to write documentation and get it added to LLVM’s docs” and help them start writing documentation as fast as possible and with as little nonsense as possible.
Overview¶
LLVM documentation is written in Markedly Structured Text (MyST) and reStructuredText (reST). MyST is a Markdown flavor that adds Sphinx documentation extensions. Markdown is preferred for new docs, and migrating old docs from reStructuredText to Markdown is an open, ongoing project. Sphinx, a documentation generator originally written for Python documentation, generates the LLVM HTML documentation from MyST and reST.
See the migration section for more information on how to migrate existing docs.
How to use this template¶
This article is located in docs/SphinxQuickstartTemplate.md.
To use it as a template, make a copy and open it in a text editor.
You can then write your docs, and open a GitHub PR to request a review.
To view the Markdown source file for this article, click Show Source on the right sidebar.
Example Section¶
An article can contain one or more sections (i.e., headings). Sections (like
Example Section above) help give your document its structure. Use # for the
document title, ## for top-level sections, ### for subsections, and so on.
Leave a blank line before and after each heading.
Example Nested Subsection¶
Subsections can also be nested beneath other subsections. For more information on Markdown syntax, see the CommonMark spec and the MyST syntax guide.
Text Formatting¶
Text can be emphasized, bold, or monospace.
To create a new paragraph, simply insert a blank line.
Links¶
You can format a link like this. A more sophisticated syntax allows you to place the [link text]: <URL> block
pretty much anywhere else in the document. This is useful when linking to especially long URLs.
Lists¶
Markdown allows you to create ordered lists…
A list starting with
1.will be automatically numbered.This is a second list element.
Use indentation to create nested lists.
…as well as unordered lists:
Stuff.
Deeper stuff.
More stuff.
Code Blocks¶
You can make blocks of code like this:
int main() {
return 0;
}
For a shell session, use a console code block (some existing docs use
bash):
$ echo "Goodbye cruel world!"
$ rm -rf /
If you need to show LLVM IR, use the llvm code block.
define i32 @test1() {
entry:
ret i32 0
}
Some other common code blocks you might need are c, objc, make,
and cmake. If you need something beyond that, you can look at the full
list of supported code blocks.
However, don’t waste time fiddling with syntax highlighting when you could be adding meaningful content. When in doubt, show preformatted text without any syntax highlighting like this:
.
+:.
..:: ::
.++:+:: ::+:.:.
.:+ :
::.::..:: .+.
..:+ :: :
......+:. ..
:++. .. :
.+:::+:: :
.. . .+ ::
+.: .::+.
...+. .: .
.++:..
...
Generating the documentation¶
You can generate the HTML documentation from the sources locally if you want to
see what they would look like. In addition to the normal
build tools
you need to install Sphinx and the necessary extensions
using the following command inside the llvm-project checkout:
pip install --user -r ./llvm/docs/requirements.txt
Then run cmake to build the documentation inside the llvm-project checkout:
mkdir build
cd build
cmake -DLLVM_ENABLE_SPHINX=On ../llvm
cmake --build . --target docs-llvm-html
In case you already have the Cmake build set up and want to reuse that,
just set the CMake variable LLVM_ENABLE_SPHINX=On.
After that you find the generated documentation in build/docs/html
folder.
Markdown migration guidelines¶
These are some goals to keep in mind during a migration:
Optimize for review: Decompose the migration into mechanical steps that are easy to review and validate.
Enable source code archaelogy: Expect future readers to want to know when documentation policy changed, so keep your changes mechanical to make that easy.
Minimize conflicts: LLVM is a big community of many developers with lots of development branches and downstreams. Make conflict resolution easy.
For that reason, it’s helpful to create 2-3 stacked pull requests:
Rename
.rst->.mdand update cross-references. This will presumably break the docs build, but to follow the one-PR-per-commit policy, it must be its own PR.Mechanically update reST conventions to markdown (`` -> `). Avoid unnecessary reflow. This means you should avoid tools like pandoc, which reflow paragraphs.
(optional) Reflow text in line with current project policy. You don’t have to do this, but if you feel the need to, make it a separate step. This can be resequenced as step 1. Separating out the text reflow step makes it easy to review and follow blame.
Don’t rely too heavily on automated error checking to catch any documentation bugs. If you are migrating a long doc, you are reponsible for building the docs locally and validating the rendering yourself using the steps above.
