First Post

This is my obligatory first post where I describe the foundations of this blog and why I started it.


My main motivation for creating this blog was to put my thoughts down in digital format. I wanted an outlet to expand upon my experiences in software engineering and the open source Python community.

Choosing a Static Site Generator

I always thought that my first blog would be backed by something like Wordpress, but that was years ago. Now that I've actually built one, I've chosen a static site generator instead. Before implementing this site, I researched several static blog engines to find one that best met my needs. Along the way, I researched Pelican, Tinkerer, and Nikola.

My main requirements for a static blogging platform were:

  • Easy to use
  • Supports reStructuredText
  • Uses Jinja for templating
  • Sufficient features
  • Not overly complicated


Pelican seemed like a solid choice and is for most people (it's the most starred Python generator on Static Gen). It supports reStructuredText, Markdown, or AsciiDoc formats, it's based on Jinja, it's easy to use, and has a good community. However, right before I was set to commit to Pelican, a friend of mine pointed out that the project was AGPL. Yikes, no thanks! I'd prefer a project with a more permissive license, e.g., MIT or BSD.


My first impression of Tinkerer was its simplicity and the fact that it utilized Sphinx for site generation. I'm somewhat familiar with Sphinx since I use it for documentation generation for some of my open source projects. It also utilized HTML5 Boilerplate out of the box which is a good base for templating. I actually chose this generator and deployed the site using it. However, one thing kept nagging at me and that was how Tinkerer organizes posts. Instead of reading the date from post metadata defined in the file, it utilizes a date aware file structure (e.g. /2015/01/02/post-name.rst). I thought I would be able to live with this but the more I thought about, the more it became a deal breaker. I had previously created the site template to be compatible with Tinkerer so I wasn't thrilled with having to port it over to another platform.


I actually considered Nikola twice. The first time was right after I looked at Pelican. I found Nikola to be similar to Pelican in scope and features with the exception that Nikola was permissively licensed (MIT). However, during my first run through of Nikola, I thought that it was perhaps more complex than what I needed. So I went with Tinkerer only to abandoned it to come back to Nikola. I ported my Tinkerer theme to Nikola and ran through Nikola's documentation in more detail. It turned out that many of the features that Nikola supported (and which I needed) were things that Tinkerer didn't:

  • Easy bundling of assets via webassets
  • Support for running CSS / JS compression
  • Sitemap generation
  • Single folder for posts
  • Pretty URLs (e.g. /mypost/ instead of /mypost.html)

I'm glad I gave Nikola another chance. It's actually been easier to set up and use than I anticipated so I'm satisfied with my choice.

Deploying to Github

I wanted to deploy my site to Github Pages from the start. There were several advantages to this:

  • No need to worry about hosting
  • Visibility on Github (source code and site deployment repositories)
  • Can edit from anywhere

In a future post I will outline the workflow I established for deploying the site using Nikola and Github Pages.

What To Expect from This Blog

I plan to mostly blog about software development with a specific focus on Python.


Comments powered by Disqus