home · contact · privacy
Fix index.html generation as well.
authorChristian Heller <c.heller@plomlompom.de>
Sat, 10 Dec 2016 23:25:00 +0000 (00:25 +0100)
committerChristian Heller <c.heller@plomlompom.de>
Sat, 10 Dec 2016 23:25:00 +0000 (00:25 +0100)
README.md
processor/feed.xml.do
processor/index.html.do

index e3ced3c39d81ff69d2f6c3f3bef59453a46da4dc..20b3becc33e3e035b0ae4410eb48446f265cb7a1 100644 (file)
--- a/README.md
+++ b/README.md
@@ -33,8 +33,5 @@ customize the blog: ./url, ./author, ./uuid, ./title.)
 bugs
 ----
 
-Due to bad shell scripting in ./processor/index.html.do (see the FIXME notes
-there), source files whose names contain "$" break the redo processing.
-
-Oh, and don't create a index.rst or index.md in the redo-managed directory,
-that will also break things.
+Don't create a index.rst or index.md in the redo-managed directory, that will
+break things.
index 001024020b2da6f777c767b3fa26b9dcd7fae740..a0349110ec24297e362ac23cc43b8b7961708a37 100644 (file)
@@ -89,4 +89,5 @@ for file in ./feed_snippets/*; do
 done
 rm -rf feed_snippets
 
+# Write feed foot.
 printf "</feed>"
index 1bd4dd13115f32556b77e065b223e8e488eb584e..dca7c33bacc4795c5e727f2bdd2dd6e3f2e062c1 100644 (file)
@@ -15,25 +15,34 @@ blog_title=`read_and_escape_file "$title_file" | head -1`
 printf "<title>%s</title>\n</head>\n<body>\n" "$blog_title"
 printf "<h1>%s</h1>\n<ul>\n" "$blog_title"
 
-# Iterate through entries sorted by lastmod of their source files, write entry.
-# FIXME: This ls parsing is a bad way to loop through the sorted files. Besides,
-# $'\0' is a bashism.
-first_run=0
-files=`ls -1t *.rst *.md | tr '\n' $'\0'`
-oldIFS="$IFS"
-IFS=$'\0'
-for file in $files; do
-  if [ "$first_run" -lt "1" ]; then
-    IFS="$oldIFS"
-    first_run=1
+# Generate link list entries.
+mkdir -p index_snippets
+for file in ./*.rst ./*.md; do
+  if [ -e "$file" ]; then
+    uuid_file="${file%.*}.uuid"
+    redo-ifchange "$uuid_file"
+    published=`stat -c%y "${uuid_file}"`
+    published_unix=$(date -u "+%s%N" -d "${published}")
+    intermediate_file="${file%.*}.intermediate"
+    html_file="${file%.*}.html"
+    redo-ifchange "$intermediate_file"
+    redo-ifchange "$html_file"
+    title_html=`cat "$intermediate_file" | head -1`
+    html_file_escaped=`escape_url "${html_file#\./}"`
+    printf "<li><a href=\"%s\" />%s</a></li>\n" "$html_file_escaped" "$title_html" > ./index_snippets/${published_unix}
   fi
-  intermediate_file="${file%.*}.intermediate"
-  html_file="${file%.*}.html"
-  redo-ifchange "$intermediate_file"
-  redo-ifchange "$html_file"
-  title_html=`cat "$intermediate_file" | head -1`
-  html_file_escaped=`escape_url "$html_file"`
-  printf "<li><a href=\"%s\" />%s</a></li>\n" "$html_file_escaped" "$title_html"
 done
 
+# Write link list.
+for file in ./index_snippets/*; do
+  touch ./index_snippets/list
+  cat "$file" ./index_snippets/list > ./index_snippets/tmp
+  mv ./index_snippets/tmp ./index_snippets/list
+done
+if [ -e "./index_snippets/list" ]; then
+  cat ./index_snippets/list
+fi
+rm -rf index_snippets
+
+# Write index footer.
 printf "</ul>\n</body>\n</html>"