Documenting history with Sphinx
Have you seen those beautiful library documentations around? For example, Bottery or Flask? They are all built with a Python library called Sphinx.
Sphinx was created to generate Pythonâs own documentation and is now widely used because it facilitates automated library documentation building. One cool thing you can do is use Sphinx to build a history of events as done in the Python Brasilâs Big Kahuna Manual.
With the goal of creating the same type of historical record for regional events, I started a repository for PythonSudeste and now also one for PyConAmazĂŽnia which, thanks to Nilo Menezes, has a complete post mortem of the organization made available to the community.
Iâll narrate here the steps I took hoping that more regional event organizers can make the same type of historical record of their events available.
Everything starts with a git repository
I started by adding two files:
requirements.txt
: this contains the libraries weâll use to generate the documentationREADME.md
: this contains information on how to run the project
The Sphinx project weâll use here runs in a virtual environment with Python 3. I particularly like using virtualenv
to create my environment:
virtualenv .env
source .env/bin/activate # may vary depending on your system
And to install the dependencies:
pip install -r requirements.txt
After installation, we start by running Sphinxâs quickstart:
sphinx-quickstart
This quickstart will ask you numerous questions about how to build your documentation. Some important points about these questions:
- Running
sphinx-quickstart
youâll need to answer things like âWhatâs the project name?â, âWhatâs the authorâs name?â and âWhatâs the content language?â, so itâs important to answer each question carefully ;) - At some point in this questionnaire, the decision is made about separating build and source, and hereâs the tip: If youâre going to put it on ReadTheDocs you do not need to commit the build \o/
At the end of this long questionnaire we just answered, youâll find a ready-to-use structure:
build/
Initially empty, but when we run the build command it will get filled up ;P
source/
Thatâs where weâll put all our files that will become pages of our project.
conf.py
The answers we gave during quickstart are stored inside this configuration file and itâs what sphinx uses to generate the .html
files from the text files. Note here that Sphinxâs preferred extension is .rst
for reStructuredText and I suspect they chose .rst
because itâs an indentation-based writing form. đ
index.rst
Itâs from index.rst
that Sphinx will build your documentationâs index.html
. If you open the index.rst on GitHub youâll see that itâs relatively simple:
This is the âfactory versionâ of index.rst
that is created when running quickstart. With it, you can already run an initial build of the site. To build the site we use make
, which is responsible for finding the .rst
files in the project directory and âtranslatingâ them to .html
. Letâs see:
make html
After running the build without errors, the result on screen should look like this:
But Jessica, why build if you said above that ReadTheDocs doesnât need it? Itâs true, but the easiest way to check the result of your work is locally and for that you need the .html
pages.
Another thing youâll need is a way to view these pages. Of course you can just open the .html
files in your favorite browser, but another option is to use a server. Servers were added as part of Python 3âs built-in http
module and are very useful in cases like this. To start a server process just run:
python -m "http.server"
And using the browser access the path localhost:8000
. While running the process from the project root as we did, you should see a listing of all files and directories in your browser:
data:image/s3,"s3://crabby-images/e568d/e568d6d0c2a11fce98a6accbbcb9a5e0c9a48387" alt=""
Then just follow the path to the folder where the .html
files are:
data:image/s3,"s3://crabby-images/84ac5/84ac5e4b9a01eec6b917206dc98867b5d63a1e3b" alt=""
When clicking on html/
, since it contains an index.html
file, your browser will show the result of the build which looks something like this using the factory-generated index.rst
:
data:image/s3,"s3://crabby-images/15e19/15e1950ddcd984047af160b4469f0ea2173c50a8" alt=""
Content Introduction \o/
All these steps so far were to prepare our project to get to the part we really want. Letâs start by creating a content page called pyconamazonia2017.rst
with just a title and create the connection between it and our index.rst
.
When running the build weâll get the following result:
data:image/s3,"s3://crabby-images/f91f1/f91f14ee8eddf40100c6ce757c5c03ce762181c2" alt=""
data:image/s3,"s3://crabby-images/df3df/df3df236bbbdb8df89bc035ea9870b951fa98903" alt=""
Changing the content of this index.rst
a bit to add a cover for example we have:
Note: the image didnât render here because the link only works within the project since it has a folder containing the image. After building, the page looks like this:
From there, just continue filling and connecting new pages in whatever way you find most interesting ;)
After all this you might think the default theme for the pages isnât great and want to change it. Sphinx has several built-in themes but here weâll use the ReadTheDocs theme. First, we start by adding it to requirements.txt
:
And then installing it like this:
(.env) $ pip install -r requirements.txt
Now we just need to change the theme variable value in the configuration file (conf.py
) to use the ReadTheDocs theme:
html_theme = 'sphinx_rtd_theme'
And when building again, your home page will look like this:
Considerations
The PyConAmazĂŽnia memorial project was structured to receive the highest number of possible contributions. If you want to check out how this is going on GitHub đ
And a tip about .rst
is to use this cheatsheet when you donât know how to do something in restructured text đ
Now, the part about putting all this online is for the next post, thatâs all folks ;)
Acknowledgments
Marco Rougeth and Silvia Benza for reviews.
data:image/s3,"s3://crabby-images/fa874/fa874bdff515008f85e41baca984ff1232546564" alt="animated jess' signature"