Skip to content
/ golb Public

Markdown&TOML based static blog generator for programmers with simple templates and plugin support.

License

Notifications You must be signed in to change notification settings

mozii/golb

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

78 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

golb

Not gold neither glob, golb == reverse(blog)

Markdown&TOML based static blog for programmers with simple templates and plugin support.

Install

pip install git+git://github.com/hit9/golb.git@v0.1.3

Usage

Usage:
  golb [--local]
  golb (-h | --help)
  golb (-v | --version)

Options:
  -h --help      show this message
  -v --version   show version
  -l --local     generate html with an empty blog url.

How-To-Start

To start bloging:

  1. make your repo directory:
mkdir -p  myblog/src/post
cd myblog
git init
  1. In the root of repo, touch conf.toml and edit:
[blog]
name = "Follow My Heart"
description = "Make difference"
templates = "classic"
url = "http://example.com"
plugins = ["gravatar", "feed", "post_summary"]
[author]
name = "hit9"
email = "nz2324@126.com"
  1. Add one set of templates as submodule, i.e. use the classic
git submodule add git://github.com/hit9/golb-templates-classic.git classic

And then set templates in section blog to classic

  1. start blog the first post:
touch src/post/HelloWorld.md

golb use toml+Markdown as post's source:

title = "Hello World!"
tags = ["tag1", "tag2"]  # tags
----
## Hello World!
  1. Generate htmls
golb -l
python -m SimpleHTTPServer 5000

see results in browser: http://localhost:5000

Each time you new a post, just touch a new markdown file in src/post and then write post with toml and markdown!

Templates

Available templates:

How to modify the templates to meet my needs?

  • fork the old repo

  • Check out classic templates to learn how to and then modify templates.

  • push to your forked repo.

  • Add your forked repo as a submodule in your blog's repo. set templates to your-forked-repo's-submodule-dir-name

Plugins

To on pulgins, in conf.toml:

plugins = ["feed","gravatar"]  # use feed and gravatar

Available plugins:

  • feed - Generate feed.atom with the latest 10 posts.

  • post_summary - Add attribute summary to each post(Html rendered from first 255 character of markdown.)

    To touch it in templaes:{{post.summary}}

  • gravatar - Add attribute: gravatar_id to author

    To touch it in templates:

    <img src="https://secure.gravatar.com/avatar/{{author.gravatar_id}}?s=200"/>

How to write my plugin, I need that!

  • checkout golb/plugins, A plugin is a single python script, write a method meets your need and then connect it to signal runtime

  • send pull request to golb, update your golb after this pull submit.

  • on the plugin in conf.toml

DEMO

Developers

  1. plugin development, checkout golb/plugins. golb use blinker to implement plugins. One plugin needs a method called register to connect to runtime signal.

  2. templates development, checkout classic.

License

MIT

About

Markdown&TOML based static blog generator for programmers with simple templates and plugin support.

Resources

License

Stars

Watchers

Forks

Packages

No packages published