3 # This is a simple script that will produce my blog on repo.or.cz
5 # The idea is to have source-<timestamp>.txt files as input, having the
6 # stories, and this script turning them into nice HTML, committing
7 # everything, and then pushing it to my repository.
9 # The blog will then be served using gitweb.
11 # To make it easier on me, if a file "source.txt" exists, it is
12 # automatically renamed using the current timestamp.
14 # TODO: generate an RSS feed, too
16 # TODO: have a configurable maximum number of entries per page, and links
19 # make sure we're in the correct working directory
22 GITWEBURL
="$(git config gitweb.url)"
23 test -z "$GITWEBURL" && {
24 echo "Please set gitweb.url in the Git config first!" >&2
28 URLPREFIX
="$(dirname "$GITWEBURL")"/
29 REMOTEREPOSITORY
="$(basename "$GITWEBURL")"
31 URL
="$REMOTEREPOSITORY?a=blob_plain;hb=$BRANCH;f="
41 move_new_entry_back
() {
42 test -f source-
$now.txt
&&
43 mv source-
$now.txt
$NEW &&
44 git
rm --cached -f source-
$now.txt
54 # add illogical suffix
56 *1?|
*[04-9]) echo "$1th";;
63 make_chinese_hour
() {
94 make_roman_number
() {
97 ?
) digit_to_roman
$1 I V X
;;
98 ??
) echo $
(digit_to_roman
${1%?} X L C
)$
(make_roman_number
${1#?});;
99 ???
) echo $
(digit_to_roman
${1%??} C D M
)$
(make_roman_number
${1#?});;
100 ????
) echo $
(digit_to_roman
${1%???} M
)$
(make_roman_number
${1#?});;
105 printf "%s, %s of %s, Anno Domini %s, at the hour of the %s\n" \
107 $
(nth $
(date +%e
-d @
$1)) \
109 $
(make_roman_number $
(date +%Y
-d @
$1)) \
110 $
(make_chinese_hour $
(date +%H
-d @
$1))
113 # make an argument for sed, to replace $1..$1 by <$2>..</$2>
114 markup_substitution
() {
116 ?
) echo "s/$1\\([^$1]*\\)$1/<$2>\\\\1<\/$2>/g";;
119 tmp2
="\\|${1%?}[^${1#?}]$tmp"
120 tmp3
="\\($tmp\\($tmp2\\($tmp2\\($tmp2\\)\\)\\)\\)"
121 echo "s/$1$tmp3$1/<$2>\\\\1<\/$2>/g"
126 # transform markup in stdin to HTML
128 image_pattern
="\\[\\[Image:\([^]]*\)"
129 image_pattern2
="$image_pattern\(\\|[^\]]*\)\?\]\]"
130 sed -e 's!^$!</p><p>!' \
131 -e 's!IMHO!in my humble opinion!g' \
132 -e 's!repo.or.cz!<a href=http://&>&</a>!g' \
133 -e 's!:-)!\☺!g' \
134 -e "s!$image_pattern2!<center><img src=$URL\1></center>!g" \
135 -e "$(markup_substitution "''" i)" \
136 -e "$(markup_substitution "_
" u)"
144 <title>$TITLE</title>
145 <meta http-equiv="Content-Type"
146 content="text/html; charset=UTF-8"/>
147 <link rel="stylesheet" type="text/css" href="$URL$CSS">
154 # timestamps will not need padding to sort correctly, for some time...
155 for file in $
(ls -r source-
*.txt
)
157 basename=${file%.txt}
158 timestamp
=${basename#source-}
159 echo "<h6>$(make_date $timestamp)</h6>"
160 echo "<h2>$(sed 1q < $file | markup)</h2>"
163 sed 1d
< $file | markup
166 sed -e 's/^./\t\t\t&/'
175 # never, ever have spaces in the file names
176 commit_new_images
() {
178 for image
in $
(cat source-
* |
180 sed -n 's/.*\[\[Image://p' |
184 git add
$image || die
"Could not git add image $image"
185 images
="$images $image"
188 git update-index
--refresh &&
189 git
diff --cached --quiet HEAD ||
190 git commit
-s -m "Commit some images on $(make_date $now)" $images
194 # parse command line option
196 *dry
*) DRYRUN
=1; shift;;
197 *show
*) firefox
"$(pwd)"/$TEST; exit;;
198 *remote
*) firefox
$URLPREFIX$URL$OUTPUT; exit;;
202 die
"Usage: $0 [--dry-run]"
204 # make sure we're on the correct branch
205 test refs
/heads
/$BRANCH = $
(git symbolic-ref HEAD
) ||
206 die
"Not on branch $BRANCH"
208 # make sure there are no uncommitted changes
209 git update-index
--refresh &&
210 git diff-files
--quiet &&
211 git diff-index
--quiet --cached HEAD ||
212 die
"Have uncommitted changes!"
214 # rename the new blog entry if it exists
217 mv -i $NEW source-
$now.txt
&&
218 git add source-
$now.txt
220 die
"Could not rename source.txt"
222 # commit the images that are referenced and not yet committed
223 test ! -z "$DRYRUN" ||
225 die
"Could not commit new images"
227 # to find the images reliably, we have to use the commit name, not the branch
228 URL
="$REMOTEREPOSITORY?a=blob_plain;hb=$(git rev-parse --verify $BRANCH);f="
230 # Rewrite the URL in the .css file if we're not running dry
234 sed -e "s/url(/&$URL/g" < $CSS.
in > $CSS &&
236 die
"Rewriting $CSS failed"
243 make_html
> $OUTPUT || die
"Could not write $OUTPUT"
245 test ! -z "$DRYRUN" && {
251 git commit
-s -m "Update $(make_date $now)" &&
252 git push origin
+$BRANCH