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 sed -e 's!^$!</p><p>!' \
130 -e 's!IMHO!in my humble opinion!g' \
131 -e 's!repo.or.cz!<a href=http://&>&</a>!g' \
132 -e 's!:-)!\☺!g' \
133 -e "s!$image_pattern\(\\|[^\]]*\)\?\]\]!<center><img src=$URL\1></center>!g" \
134 -e "$(markup_substitution "''" i)" \
135 -e "$(markup_substitution "_
" u)"
143 <title>$TITLE</title>
144 <meta http-equiv="Content-Type"
145 content="text/html; charset=UTF-8"/>
146 <link rel="stylesheet" type="text/css" href="$URL$CSS">
153 # timestamps will not need padding to sort correctly, for some time...
154 for file in $
(ls -r source-
*.txt
)
156 basename=${file%.txt}
157 timestamp
=${basename#source-}
158 echo "<h6>$(make_date $timestamp)</h6>"
159 echo "<h2>$(sed 1q < $file | markup)</h2>"
162 sed 1d
< $file | markup
165 sed -e 's/^./\t\t\t&/'
174 # never, ever have spaces in the file names
175 commit_new_images
() {
177 for image
in $
(cat source-
* |
179 sed -n 's/.*\[\[Image://p' |
183 git add
$image || die
"Could not git add image $image"
184 images
="$images $image"
187 git update-index
--refresh &&
188 git
diff --cached --quiet HEAD ||
189 git commit
-s -m "Commit some images on $(make_date $now)" $images
193 # parse command line option
195 *dry
*) DRYRUN
=1; shift;;
196 *show
*) firefox
"$(pwd)"/$TEST; exit;;
197 *remote
*) firefox
$URLPREFIX$URL$OUTPUT; exit;;
201 die
"Usage: $0 [--dry-run]"
203 # make sure we're on the correct branch
204 test refs
/heads
/$BRANCH = $
(git symbolic-ref HEAD
) ||
205 die
"Not on branch $BRANCH"
207 # make sure there are no uncommitted changes
208 git update-index
--refresh &&
209 git diff-files
--quiet &&
210 git diff-index
--quiet --cached HEAD ||
211 die
"Have uncommitted changes!"
213 # rename the new blog entry if it exists
216 mv -i $NEW source-
$now.txt
&&
217 git add source-
$now.txt
219 die
"Could not rename source.txt"
221 # commit the images that are referenced and not yet committed
222 test ! -z "$DRYRUN" ||
224 die
"Could not commit new images"
226 # to find the images reliably, we have to use the commit name, not the branch
227 URL
="$REMOTEREPOSITORY?a=blob_plain;hb=$(git rev-parse --verify $BRANCH);f="
229 # Rewrite the URL in the .css file if we're not running dry
233 sed -e "s/url(/&$URL/g" < $CSS.
in > $CSS &&
235 die
"Rewriting $CSS failed"
242 make_html
> $OUTPUT || die
"Could not write $OUTPUT"
244 test ! -z "$DRYRUN" && {
250 git commit
-s -m "Update $(make_date $now)" &&
251 git push origin
+$BRANCH