Not gold
neither glob
, golb == reverse(blog)
Markdown&TOML based static blog for programmers with simple templates and plugin support.
pip install git+git://github.com/hit9/golb.git@v0.1.3
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.
To start bloging:
- make your repo directory:
mkdir -p myblog/src/post
cd myblog
git init
- 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"
- 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
- 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!
- 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!
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
toyour-forked-repo's-submodule-dir-name
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
-
plugin development, checkout golb/plugins. golb use
blinker
to implement plugins. One plugin needs a method calledregister
to connect toruntime
signal. -
templates development, checkout classic.
MIT