/Markablog

Static site generator in Perl, Markdown

Primary LanguagePerlMIT LicenseMIT

Markablog Remarkably Simple Blogging

Overview

This script accepts Markdown as input and builds a blog style website.

Everything is an asset, the effort for every task is distilled.

It's unique in that it allows you to not do very much to dramatically change the site. Here's why:

  • Anything you put in the posts directory will become a post in the index.
  • Anything you put in the pages directory will become a page in the navbar.
  • Anything you put in the CSS directory will be come a stylesheet for everything.
  • Any word you write will be beautifully styled thanks to Bootstrap.
  • Any code you write will be beautifully highlighted thanks to Prettyprint.
  • Any math you write will be beautifully rendered thanks to MathJax.

Quick start

You should download the source, place Markdown files in the posts directory, and run build.

If you'd like to sort your posts, you need to have your naming format be alphanumerically and lexicographically sortable. The naming standard that's built into Markable is [YEARMNDY]["Title"].md.

If you'd like the date displayed in your post, you'll need to use something like this:

This is the title of my post {{meta}}
-------------------------------------

The {{meta}} will be replaced by a date and a clickable link to a page with only this post.

Replace the metadata in build.pl to get a custom title for your site.

The title and URL of every post in the browser is determined by the filename, everything else in the file is determined by you.

To edit the About page, edit about.md.

Design Goals

The design goals of this project are the same as the design goals of my website:

  • Simple, easy, lightweight
  • Scalable, fast web-hosting
  • Custom domain name
  • Cheap or free
  • Write posts in Markdown alone

Comparable Tools

I do not at all claim to have feature parity with these services, but I looked into these static blog generators before deciding to write my own:

To do

  • Categories
    • Each folder in the posts directory will be a category
    • Each category will have its own index
  • Tags
    • A hashtag implementation a la Twitter
    • A hashtag in a post will enter that post into a ordered list in a unified Tags.html page.
  • Site map
    • A linked list of every post