How I moved to GitHub & JBake

*** This page is under construction unfinished… ***

First: It’s not my invention! Many did it before, there are lots of description out there. It still took me some time ;)

This and this was the most inspiring source and easiest explanation (that gives confidence ;) ).

Setup

So this is the overall setup I have:

  • A directory on my Mac that holds the content. I use the basic structure that Jbake uses.
  • A git-cloned directory on my Mac with the output of the jBake-process
  • A little script that I run every time I modified something. The script does the baking and the git-publishing
  • And of course the settings in the DNS to point my Domain name to the Github IPs

JBake

Why do I use JBake? I like the principle and I feel more comfortable in Java than in other programming languages. I haven’t touched the JBake internal code, but I feel confident that I could. The principle way that JBake operates is similar to the famous Jekyll: It parses content files and creates (static) HTML files out of it. The content files can contain Markdown or some other formats; I just use Markdown.

My directory structure looks like this:

.
|-- assets
|   |-- favicon.gif
|   |-- robots.txt
|   |-- img
|   |   |-- logo.png
|   |-- js
|   |   |-- custom.js
|   |-- css
|       |-- style.css
|
|-- content
|   |-- about.html
|   |-- 2013
|       |-- 01
|       |   |-- hello-world.html
|       |-- 02 
|           |-- weekly-links-1.ad
|           |-- weekly-links-2.md
|
|-- templates
|   |-- index.ftl
|   |-- page.ftl
|   |-- post.ftl
|   |-- feed.ftl
|
|-- jbake.properties

By default JBake produces the output directory into this tree. In my case I bake my stuff into a directory that is git-synced.

The GitHub setup

The DNS settings

Next up

There are a couple of things I plan to change.