From: Christian Heller <c.heller@plomlompom.de> Date: Sat, 10 Dec 2016 23:25:00 +0000 (+0100) Subject: Fix index.html generation as well. X-Git-Url: https://plomlompom.com/repos/%7B%7Bprefix%7D%7D/static/%7B%7B%20web_path%20%7D%7D/bar%20baz.html?a=commitdiff_plain;h=6138fd7efef3873fa3f48b92f2275f86eb76e329;p=redo-blog Fix index.html generation as well. --- diff --git a/README.md b/README.md index e3ced3c..20b3bec 100644 --- 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. diff --git a/processor/feed.xml.do b/processor/feed.xml.do index 0010240..a034911 100644 --- a/processor/feed.xml.do +++ b/processor/feed.xml.do @@ -89,4 +89,5 @@ for file in ./feed_snippets/*; do done rm -rf feed_snippets +# Write feed foot. printf "</feed>" diff --git a/processor/index.html.do b/processor/index.html.do index 1bd4dd1..dca7c33 100644 --- a/processor/index.html.do +++ b/processor/index.html.do @@ -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>"