In the previous blog - Writing Documentation on Read the Docs - Part 1 we installed sphinx and configured it to use Markdown and sphinx-rtd-theme. In this blog, we will find out how to write docs and add contents to it.
Writing the docs
Make sure you have setup your project to use Markdown and have configured conf.py to use sphinx-rtd-theme, if not then please have a look at Part 1 of this blog.
We will be using Atom IDE to write our documentation, though you can use any other Text Editor like Notepad, or Sublime Text.
We will be using Atom IDE to write our documentation, though you can use any other Text Editor like Notepad, or Sublime Text.
Create a new page and add it to your project :
Add a new file in your docs/ directory and give it an extension *.md , in the example shown below, I have created a file named Writing-Documentation.md .
Add new file in docs/ folder and give it extension *.md |
To make this page appear in the Contents section of your project, add an entry in the index.rst as shown in the figure above. Note that the name should be exactly the same as your filename without the extension '.md' . Take note of type-case sensitivity.
Basic Formatting
You can use basic formatting options like add Headers, Lists, add images and Links in Markdown.
Github has a list of common formatting options available in their Markdown-cheatsheet.
Github has a list of common formatting options available in their Markdown-cheatsheet.
Markdown Cheatsheet - Img Courtesy guides.github.com |
Adding images and gifs
All images and gifs needs to be placed inside the docs/_static directory of your project.
Once the files have been place in the _static directory, we can link the images in the documentation using the following syntax -
Once the files have been place in the _static directory, we can link the images in the documentation using the following syntax -
![CPU Close-up](_static/cpu-close-up.jpg)
Here I have added a close photograph of a modern Intel CPU.
Adding image in your documentation |
Image of a Modern-day CPU |
Adding Permalinks to Headers
Headers are automatically numbered by sphinx, this makes it easy to divide pages into sections and sub-sections.
The topmost header (h1) corresponds to # in Markdown, to define sub-sections you can just add more headers using double hashes ## and further sub-sections using ### and so on.
To add permalink to your sub-sections, you need to use the markup for Link and in the parenthesis write the name of the heading in the following way :
So if you've a header 'Introduction to Read the Docs' in your page then to add permalink to it, you need to write
- [Introduction to Read the Docs](#introduction-to-read-the-docs)
NOTE : The text inside the parenthesis must always be in small case and words separated by hypen (-). The text must always begin with # even when adding link to header (h2, h3 or any other).The topmost header (h1) corresponds to # in Markdown, to define sub-sections you can just add more headers using double hashes ## and further sub-sections using ### and so on.
To add permalink to your sub-sections, you need to use the markup for Link and in the parenthesis write the name of the heading in the following way :
So if you've a header 'Introduction to Read the Docs' in your page then to add permalink to it, you need to write
- [Introduction to Read the Docs](#introduction-to-read-the-docs)
Building your project as HTML Document
To build your project as HTML Document run the following command from docs/ directory of your project -
$ make html