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
15 # TODO: have a configurable maximum number of entries per page, and links
18 # make sure we're in the correct working directory
21 GITWEBURL
="$(git config gitweb.url)"
22 test -z "$GITWEBURL" && {
23 echo "Please set gitweb.url in the Git config first!" >&2
27 URLPREFIX
="$(dirname "$GITWEBURL")"/
28 REMOTEREPOSITORY
="$(basename "$GITWEBURL")"
30 URL
="$REMOTEREPOSITORY?a=blob_plain;hb=$BRANCH;f="
40 move_new_entry_back
() {
41 test -f source-
$now.txt
&&
42 mv source-
$now.txt
$NEW &&
43 git
rm --cached -f source-
$now.txt
53 # add illogical suffix
55 *1?|
*[04-9]) echo "$1th";;
62 make_chinese_hour
() {
93 make_roman_number
() {
96 ?
) digit_to_roman
$1 I V X
;;
97 ??
) echo $
(digit_to_roman
${1%?} X L C
)$
(make_roman_number
${1#?});;
98 ???
) echo $
(digit_to_roman
${1%??} C D M
)$
(make_roman_number
${1#?});;
99 ????
) echo $
(digit_to_roman
${1%???} M
)$
(make_roman_number
${1#?});;
104 printf "%s, %s of %s, Anno Domini %s, at the hour of the %s\n" \
106 $
(nth $
(date +%e
-d @
$1)) \
108 $
(make_roman_number $
(date +%Y
-d @
$1)) \
109 $
(make_chinese_hour $
(date +%H
-d @
$1))
112 # make an argument for sed, to replace $1..$1 by <$2>..</$2>
113 markup_substitution
() {
115 ?
) echo "s/$1\\([^$1]*\\)$1/<$2>\\\\1<\/$2>/g";;
118 tmp2
="\\|${1%?}[^${1#?}]$tmp"
119 tmp3
="\\($tmp\\($tmp2\\($tmp2\\($tmp2\\)\\)\\)\\)"
120 echo "s/$1$tmp3$1/<$2>\\\\1<\/$2>/g"
125 # transform markup in stdin to HTML
127 image_pattern
="\\[\\[Image:\([^]]*\)"
128 image_pattern2
="$image_pattern\(\\|[^\]]*\)\?\]\]"
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_pattern2!<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">
155 toc_style
="position:absolute;top:50px;left:810px;width=$toc_width"
156 echo "<div style=\"$toc_style\">"
157 echo "<table width=$toc_width bgcolor=#e0e0e0 border=1><tr><td>"
159 for file in $
(ls -r source-
*.txt
)
161 basename=${file%.txt}
162 timestamp
=${basename#source-}
163 date="$(date +"%d
%b
%Y
" -d @$timestamp)"
164 title
="$(sed 1q < $file | markup)"
165 echo "<li><a href=#$timestamp>$date $title</a>"
167 echo '</td></tr></table>'
172 # timestamps will not need padding to sort correctly, for some time...
173 for file in $
(ls -r source-
*.txt
)
175 basename=${file%.txt}
176 timestamp
=${basename#source-}
177 echo "<h6>$(make_date $timestamp)</h6>"
178 echo "<a name=$timestamp>"
179 echo "<h2>$(sed 1q < $file | markup)</h2>"
182 sed 1d
< $file | markup
185 sed -e 's/^./\t\t\t&/'
194 # never, ever have spaces in the file names
195 commit_new_images
() {
197 for image
in $
(cat source-
* |
199 sed -n 's/.*\[\[Image://p' |
203 git add
$image || die
"Could not git add image $image"
204 images
="$images $image"
207 git update-index
--refresh &&
208 git
diff --cached --quiet HEAD ||
209 git commit
-s -m "Commit some images on $(make_date $now)" $images
213 # parse command line option
215 *dry
*) DRYRUN
=1; shift;;
216 *show
*) firefox
"$(pwd)"/$TEST; exit;;
217 *remote
*) firefox
$URLPREFIX$URL$OUTPUT; exit;;
221 die
"Usage: $0 [--dry-run]"
223 # make sure we're on the correct branch
224 test refs
/heads
/$BRANCH = $
(git symbolic-ref HEAD
) ||
225 die
"Not on branch $BRANCH"
227 # make sure there are no uncommitted changes
228 git update-index
--refresh &&
229 git diff-files
--quiet &&
230 git diff-index
--quiet --cached HEAD ||
231 die
"Have uncommitted changes!"
233 # rename the new blog entry if it exists
236 mv -i $NEW source-
$now.txt
&&
237 git add source-
$now.txt
239 die
"Could not rename source.txt"
241 # commit the images that are referenced and not yet committed
242 test ! -z "$DRYRUN" ||
244 die
"Could not commit new images"
246 # to find the images reliably, we have to use the commit name, not the branch
247 URL
="$REMOTEREPOSITORY?a=blob_plain;hb=$(git rev-parse --verify $BRANCH);f="
249 # Rewrite the URL in the .css file if we're not running dry
253 sed -e "s/url(/&$URL/g" < $CSS.
in > $CSS &&
255 die
"Rewriting $CSS failed"
262 make_html
> $OUTPUT || die
"Could not write $OUTPUT"
264 test ! -z "$DRYRUN" && {
270 git commit
-s -m "Update $(make_date $now)" &&
271 git push origin
+$BRANCH