I've been experimenting with several popular markup languages for writing documentation on GitHub's wikis: GitHub Flavored Markdown, AsciiDoc, and reStructuredText.
AsciiDoc and reStructuredText offer advanced formatting features unavailable to GFM. Many of these features are not available in GitHub's wikis, because GitHub strips off most HTML tags and styles from the rendered HTML.
Here's a summary of my opinions on all three. Note that while I have plenty of experience with Markdown, I've used AsciiDoc and reStructuredText for only a few days. I may be poorly informed or biased.
GitHub Flavored Markdown
Pros
- Easy and widespread
- Can mix HTML
- Simple table format
- Can align table content using GFM markup
Cons
- Table cells cannot span multiple rows or columns (workaround: use HTML tables)
- No native support for definition lists (though HTML can be used directly)
- No table of contents, though there are tools that can generate TOCs for you:
- markdown-toc
- DocToc
- gh-md-toc
- GitHub Wiki TOC generator is an online Markdown TOC generator.
- No footnotes
- No native definition lists, though HTML can be used.
AsciiDoc
Pros
- Table cells can natively span multiple rows or columns
- Admonitions
- Auto-Numbered Appendix
- Definition lists (AKA labeled lists)
- Footnotes
- Table of contents
- Collapsible sections (rendered as
<details>
tags) - Can use HTML using passthrough macros
Cons
- No strikethrough or underline syntax (workaround: use HTML tags)
- Large margins between list items, due to them being enclosed in
<p>
tags. See relevant AsciiDoctor issue on GitHub. - Large padding in table cells, also due to them being enclosed in
<p>
tags.
Also check out tips on using AsciiDoc in GitHub.
reStructuredText
Pros
- Familiar to Python developers, since the language (and many software written in it) uses reStructuredText for documentation.
- Table cells can natively span multiple rows or columns
- Definition lists
- Footnotes that can be inserted anywhere, not just the bottom of the page
- Table of contents (use the
contents
directive, sincetoctree
is unsupported in GitHub)
Cons
- No strikethrough or underline syntax (see docutils docs on why underline is missing)
- Verbose and strict table syntax
- Difficult to determine the level of a heading, if you haven't unified and memorized the hierarchy of heading underline symbols.
- Table column width is controlled by the renderer instead of being managed by the browser. This may result in undesirable layouts on small screens.
- Limited support for direct HTML, using the
.. raw:: html
directive.