summaryrefslogtreecommitdiff
path: root/src/post-commit.sh
diff options
context:
space:
mode:
authorp4bl0 <pablo@rauzy.name>2010-07-23 03:02:23 +0200
committerp4bl0 <pablo@rauzy.name>2010-07-23 03:02:23 +0200
commitf59b2bd1d4f8ff3548af12e9ca9367562e60373c (patch)
tree8a9b07c1abf96c6ea3374f42360b8b7f70f9370f /src/post-commit.sh
parent4467a42aee94c85868fc4c706669fcf89707bce3 (diff)
in fact a Makefile makes no sens here, what I'll need is juste un build script. Thus src dir has no more any reason to be
Diffstat (limited to 'src/post-commit.sh')
-rw-r--r--src/post-commit.sh115
1 files changed, 0 insertions, 115 deletions
diff --git a/src/post-commit.sh b/src/post-commit.sh
deleted file mode 100644
index c028f85..0000000
--- a/src/post-commit.sh
+++ /dev/null
@@ -1,115 +0,0 @@
-#!/bin/sh
-
-public_dir=`git config --get fugitive.public-dir`
-if [ ! -d "$public_dir" ]; then mkdir -p "$public_dir"; fi
-templates_dir=`git config --get fugitive.templates-dir`
-articles_dir=`git config --get fugitive.articles-dir`
-
-added_files=`git log -1 --name-status --pretty="format:" | grep -E '^A' | \
- cut -f2`
-modified_files=`git log -1 --name-status --pretty="format:" | grep -E '^M' | \
- cut -f2`
-deleted_files=`git log -1 --name-status --pretty="format:" | grep -E '^D' | \
- cut -f2`
-
-last_published_article=`git log --name-status --pretty="format:" | \
- grep -E '^A' | cut -f2 | grep -E '^$articles_dir' | head -1`
-
-sanit_mail() {
- sed "s/@/[at]/;s/\./(dot)/"
-}
-
-commit_Hash=`git log -1 --format="%H"`
-commit_hash=`git log -1 --format="%h"`
-commit_author=`git log -1 --format="%an"`
-commit_author_email=`git log -1 --format="%ae" | sanit_mail`
-commit_datetime=`git log -1 --format="%ai"`
-commit_date=`git log -1 --format="%ad" --date="short"`
-commit_time=`git log -1 --format="%ai" | cut -d' ' -f2`
-commit_timestamp=`git log -1 --format="%at"`
-commit_subject=`git log -1 --format="%s"`
-commit_slug=`git log -1 --format="%f"`
-commit_body() {
- tmp=`tempfile -p "fugitive"`
- git log -1 --format="%b" > "$tmp"
- (sleep 5 && rm -f "$tmp") & # this message will self-destruct in 5s
- echo "$tmp"
-}
-
-article_info() {
- git log --format="$1" -- "$2"
-}
-article_title() {
- head -1 "$1"
-}
-article_content() {
- tmp=`tempfile -p "fugitive"`
- tail -n+2 "$1" > "$tmp"
- (sleep 5 && rm -f "$tmp") & # this message will self-destruct in 5s
- echo "$tmp"
-}
-
-replace_var_by_string() {
- sed "s/<?fugitive\s\+$1\s*?>/$2/"
-}
-replace_var_by_file() {
- sed "/<?fugitive\s\+$1\s*?>/ {
- r $2
- d }"
-}
-replace_commit_info() {
- replace_var_by_string "commit_Hash" "$commit_Hash" | \
- replace_var_by_string "commit_hash" "$commit_hash" | \
- replace_var_by_string "commit_author" "$commit_author" | \
- replace_var_by_string "commit_author_email" "$commit_author_email" | \
- replace_var_by_string "commit_datetime" "$commit_datetime" | \
- replace_var_by_string "commit_date" "$commit_date" | \
- replace_var_by_string "commit_time" "$commit_time" | \
- replace_var_by_string "commit_timestamp" "$commit_timestamp" | \
- replace_var_by_string "commit_subject" "$commit_subject" | \
- replace_var_by_string "commit_slug" "$commit_slug" | \
- replace_var_by_file "commit_body" "`commit_body`"
-}
-replace_article_info() {
- cdt=`article_info "%ai" "$1" | tail -1`
- mdt=`article_info "%ai" "$1" | head -1`
- replace_var_by_file "article_content" "`article_content \"$1\"`" | \
- replace_var_by_string "article_title" "`article_title \"$1\"`" | \
- replace_var_by_string "article_cdatetime" "$cdt" | \
- replace_var_by_string "article_cdate" "`echo $cdt | cut -d' ' -f1`" | \
- replace_var_by_string "article_ctime" "`echo $cdt | cut -d' ' -f2`" | \
- replace_var_by_string "article_ctimestamp" \
- "`article_info \"%at\" \"$1\" | tail -1`" | \
- replace_var_by_string "article_mdatetime" "$mdt" | \
- replace_var_by_string "article_mdate" "`echo $mdt | cut -d' ' -f1`" | \
- replace_var_by_string "article_mtime" "`echo $mdt | cut -d' ' -f2`" | \
- replace_var_by_string "article_mtimestamp" \
- "`article_info \"%at\" \"$1\" | head -1`" | \
- replace_var_by_string "article_cauthor" \
- "`article_info \"%an\" \"$1\" | tail -1`" | \
- replace_var_by_string "article_cauthor_email" \
- "`article_info \"%ae\" \"$1\" | tail -1 | sanit_mail`" | \
- replace_var_by_string "article_mauthor" \
- "`article_info \"%an\" \"$1\" | head -1`" | \
- replace_var_by_string "article_mauthor_email" \
- "`article_info \"%ae\" \"$1\" | head -1 | sanit_mail`"
-}
-
-for f in $deleted_files; do
- if [ "$f" != "${f#$articles_dir}" ]; then
- echo -n "Deleting $public_dir/${f#$articles_dir/}.html... "
- rm $public_dir/${f#$articles_dir/}.html
- echo "done."
- fi
-done
-
-for f in $added_files $modified_files; do
- if [ "$f" != "${f#$articles_dir}" ]; then
- echo -n "Generating $public_dir/${f#$articles_dir/}.html from $f... "
- cat $templates_dir/article.html | \
- replace_commit_info | \
- replace_article_info "$f" | \
- cat > $public_dir/${f#$articles_dir/}.html
- echo "done."
- fi
-done