Markdown Guide
Section Headings
The following sections describe the section heading pattern that Chef is using for topic titles, H1s, H2s, H3s and H4s.
As a general rule, limit the number of heading levels to no more than two within a topic. There can be exceptions, especially if the document is large, but remember that HTML TOC structures usually have width limitations (on the display side) and the more structure within a TOC, the harder it can be for users to figure out what is in it.
Unless the topics are about installing things or about API endpoints, the headings should never wrap. Keep them to a single line.
The width of heading adornment must be at least equal to the length of the text in the heading and the same width for headings is used everywhere. Consistent width is preferred.
Note
H1
The H1 heading is reserved for the page title which is created by the Hugo page template. The Markdown file text should not have any H1 headings.
H2
Use two hash characters (##) before the heading name to indicate H2 headings:
## H2 Heading
This is the body.
H3
Use three hash characters (###) before the heading name to indicate H3 headings:
### H3 Heading
This is the body.
H4
Use four hash characters (####) before the heading name to indicate H4 headings:
#### H4 Heading
This is the paragraph.
Other Headings
If you need more than four heading levels, use bold emphasis and then white space to make the heading text stand out and separate the heading from the content:
**heading name goes here** # bold emphasis
# blank line
content, as normally authored.
Lists
The following sections describe conventions for lists in Chef docs.
Bulleted Lists
Bulleted lists break up text blocks and draw attention to a group of items:
- text goes here
- text goes here
- subitem text
- subitem text
- text goes here
- text goes here
Use the dash symbol (-) for bulleted lists, even though Hugo supports other symbols. Indent nested list items by four spaces.
Numbered Lists
Numbered lists are created like this:
1. text goes here
1. text goes here
1. text goes here
1. sub-list text
1. sub-list text
1. text goes here
Start each ordered list item with the number 1 (1.). Hugo will generate the correct sequence of numbers in an ordered list regardless of the numbers that you use. Only using “1.” will save you from having to re-number items if you add or remove an item later.
Definition Lists
Use a definition list to define terms, including CLI commands, command flags, parameters, and properties.
You can include more than definition for a term and more than one paragraph for a definition. Each definition should have a :
at the beginning of the line of text, a space, and then the definition text. Additional paragraphs just need to be indented by two spaces. See the example below:
Note
(@)
after the term. For example, [term](@)
. In the example below, another term has an ID.term
: Term definition.
[another term](@)
: Another term definition.
You can include multiple paragraphs in a definition if you need to.
: You can include more than one definition for a term by starting another line with a colon.
: Adding square brackets and the `(@)` symbol around the term (`[another term](@)`) add a linkable ID to the term.
The example above produces the following output:
- term
- Term definition.
- another term
- Another term definition.
You can include multiple paragraphs in a definition if you need to.
You can include more than one definition for a term by starting another line with a colon.
Adding square brackets and the
(@)
symbol around the term ([another term](@)
) adds a linkable ID to the term.
Tables
Create tables in Markdown like this:
Chef Software | Description
--------|------
Chef Infra Client | Awesome
Chef Infra Server | Fun
Chef Habitat | Super cool
Use three or more hyphens (—) to separate each column’s header from the content of the table. Separate columns with a vertical bar or pipe (|).
Note
Inline Markup
Adding emphasis within text strings can be done using bold and
code strings
.
Bold
Use two asterisks (*) to mark a text string as bold:
**text goes here**
Code Strings
Sometimes the name of a method or database field needs to be used inline
in a paragraph. Use one back quote to mark certain strings as code
within a regular string of text:
code goes here
Code Blocks
Code blocks are used to show code samples, such as those for Ruby, JSON, and command-line strings.
Ruby
Use this approach to show code blocks that use Ruby:
default['apache']['dir'] = '/etc/apache2'
default['apache']['listen_ports'] = [ '80', '443' ]
Bash
Use this approach to show code blocks that use any type of shell command, such as for Knife or the Chef Infra Client or for any other command-line example that may be required:
knife data bag create admins
JavaScript (and JSON)
Use this approach to show code blocks that use any type of JavaScript, including any JSON code sample:
{
"id": "charlie",
"uid": 1005,
"gid":"ops",
"shell":"/bin/zsh",
"comment":"Crazy Charlie"
}
Literal
Literals should be used sparingly, but sometimes there is a need for a block of text that does not work in a fenced code block, such as showing a directory structure, basic syntax, or pseudocode. To make a literal code block, indent the text by four spaces:
A block of literal text indented four spaces
with more
text as required to
complete the block of text.
Images
You have two options for formatting images in Hugo:
- Markdown syntax
- the
figure
shortcode
Markdown Syntax
To add an image in Markdown, use an exclamation point, square brackets around the alt text, parenthesis around the path to the image file starting in the static
directory, and then optional hover text. For example:
![Alt Text](/path/to/img.png "Optional Title")
Figure Shortcode
The figure shortcode allows you to specify the image size and include a title, a caption, and alternate text.
SVG images should be formatted using the figure
shortcode.
{{< figure src="/images/chef-logo.svg" title="Chef Logo" height="100" width="150" >}}
Which looks like this:
Raster images should be 96 dpi and no larger than 600 pixels wide. This helps ensure that the image can be printed and/or built into other output formats; in some cases, separate 300 dpi files should be maintained for images that require inclusion in formats designed for printing and/or presentations.
Fontawesome Shortcode
The Fontawesome shortcode will display any free Font Awesome icon in a page.
It accepts the following parameters:
background-color
border
border-radius
class
color
font-size
margin
padding
The only required parameter is class
, which is the same as the class name of the icon.
The following shortcode examples will display these icons:
{{< fontawesome class="fas fa-ellipsis-h" >}}
{{< fontawesome class="fas fa-anchor" font-size="3rem" border="2px dashed" padding="1px" border-radius="5px" >}}
{{< fontawesome class="fas fa-archive" color="#cc814b" margin="0 0 0 12px">}}
{{< fontawesome class="far fa-address-book" background-color="DarkBlue" color="rgb(168, 218, 220)" >}}
SVG Shortcode
You can also add an inline SVG image into a line of text using the svg shortcode. Use this for adding SVG icons that Fontawesome doesn’t include in their free tier.
For example, this will add an SVG icon to a string of text:
Click on the web asset icon ({{< svg src="themes/docs-new/static/images/web-asset.svg" >}}).
which produces this output:
Click on the web asset icon ( ).
Markdownlint
We use Markdownlint in a GitHub action to lint the Markdown in each pull request. See the Markdownlint repository for information about the different Markdown rules that the linter will check for.
If necessary, you can enable or disable Markdownlint for a line, section of a page, or an entire page. See the Markdownlint documentation for additional information.