shithub: werc

Download patch

ref: b22c5073d4e7f3ea1729c9f6d6f04e18a57c57bd
parent: 2b31fa7840de07746fee6eb1eaaa97e6274d9e26
author: uriel <uriel@engel.se.cat-v.org>
date: Sat Dec 20 08:20:31 EST 2008

Sitemap improvemnts and cleanups:

- Avoid nedless tests
- Replace reference to /bin/sed with faster, simpler and probably more correct plan9 sed call.
- Move inline html styling to style.css
- Various code cleanups, bring source style in line with other werc source.

--- a/lib/sitemap.tpl
+++ b/lib/sitemap.tpl
@@ -3,7 +3,7 @@
 %{
 tmpfile=/tmp/werc_sitemap_$pid.txt
 echo '' > $tmpfile
-saveddf = $dirfilter
+saveddf=$dirfilter
 
 fn getMdDesc {
     sed 's/^(.......................................................................................................[^ ]*).*$/\1/g; 1q' < $1 
@@ -11,44 +11,49 @@
 
 fn listDir {
     d=$1
-    dirfilter = $saveddf
-    blogDirs = ()
-    if (test -f $d/_werc/config)
-        . $d/_werc/config
+    if(~ $#d 0)
+        d=''
+    dirfilter=$saveddf
+    blogDirs=()
+    if(test -f $d/_werc/config)
+        . ./$d/_werc/config
 
-    echo '<ul>'
+    echo '<ul class="sitemap-list">'
 
     # Don't hide blog dirs for now
-    #if (! ~ $#blogDirs 0 || ~ $1 */blog */Blog )
+    #if(! ~ $#blogDirs 0 || ~ $1 */blog */Blog)
     #    echo '' 
     #if not 
     if(! ~ $#redirectPermanent 1)
     {
 
-    for ( i in `{ ls -d $d/*/ $d/*.md $d/*.html $d/*.txt >[2]/dev/null |sed $dirfilter} ) {
-        desc = ''
-        if (test -f $i.md) {
-            desc = `{ getMdDesc $i.md }
-        }
-        if (test -f $i/index.md) {
-            desc = `{ getMdDesc $i/index.md }
-        }
-        if (test -f $i.html) {
+    for(i in `{ls -dF $d^*/ $d^*.md $d^*.html $d^*.txt >[2]/dev/null | sed $dirfilter}) {
+        desc=''
+        if(test -f $i.md)
+            desc=`{getMdDesc $i.md}
+        if not if(~ $i */ && test -f $i/index.md)
+            desc=`{getMdDesc $i/index.md}
+        if not if(test -f $i.html) {
             # H1 is not reliable because htmlroff doesn't use it :(
-            #desc = `{ cat $i.html |sed 32q | grep '<[Hh]1>' |sed 's/<[Hh]1>(.*)(<\/[Hh]1>|$)/\1/;s/<[^>]*>//g;1q'  } 
+            #desc = `{cat $i.html |sed 32q | grep '<[Hh]1>' |sed 's/<[Hh]1>(.*)(<\/[Hh]1>|$)/\1/;s/<[^>]*>//g;1q'}
             # Pick the first line of body  instead
-            desc = `{ /bin/sed -e '0,/<[Bb][Oo][Dd][Yy]/d;s/<[^>]*>//g;/^$/d' < $i.html >[2]/dev/null | sed 1q }
+            desc=`{sed -n '/<[Bb][Oo][Dd][Yy]/,/./s/(<[^>]*>|$)//gp' < $i.html}
+            if(~ $#desc 0)
+                desc=`{sed 's/<[^>]*>//g; 1q' < $i.html}
+            #desc=`{/bin/sed -e '0,/<[Bb][Oo][Dd][Yy]/d;s/<[^>]*>//g;/^$/d' < $i.html >[2]/dev/null | sed 1q}
         }
-        if (! ~ $desc '')
-            desc = ' - '$"desc
-        tit = `{basename $i|sed 's/_/ /g'}
-        echo '<li><a style="text-transform: capitalize" href="/'$i'">'^$"tit^'</a>' $desc '</li>' 
+
+        if(! ~ $#desc 0 && ! ~ $desc '')
+            desc=' - '$"desc
+        tit=`{echo /$i|sed 's/_/ /g; s,.*/([^/]+)/?$,\1,'}
+        echo '<li><a href="/'$i'">'^$"tit^'</a>' $"desc '</li>' 
         echo -n $baseuri^$i >> $tmpfile
-        if (test -d $i) {
+        if(test -d $i) {
             echo / >> $tmpfile	
             @{ listDir $i }
         }
-        if not echo >> $tmpfile
+        if not
+            echo >> $tmpfile
     }
     }
     echo '</ul>'
@@ -55,7 +60,7 @@
 }
 
 cd $sitedir 
-listDir .
+listDir ''
 
 cp $tmpfile ./sitemap.txt
 rm $tmpfile
--- a/pub/style/style.css
+++ b/pub/style/style.css
@@ -369,3 +369,6 @@
     text-transform: capitalize;
     font-weight: bold;
 }
+ul.sitemap-list a {
+    text-transform: capitalize;
+}