#!/bin/sh # Copyright (C) Philipp 'ph3-der-loewe' Schafft - 2009-2011 # # This file is part of webgen, # a small template engine for easy management of small websites. # # This file is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License version 3 # as published by the Free Software Foundation. # # webgen is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this software; see the file COPYING. If not, write to # the Free Software Foundation, 51 Franklin Street, Fifth Floor, # Boston, MA 02110-1301, USA. # CONFIG: OUT=`pwd` TPLS=tpl/ HEADER=header END=end PAGE_SUFFIX='.html' TEMPLATES="$1" DEFAULT_MENU='-menu-none' [ "$TEMPLATES" = '' ] && TEMPLATES="*" if [ "$TEMPLATES" = '+' ] then TEMPLATES_PAGE="*" TEMPLATES_DYN="NO-TEMPLATES" elif [ "$TEMPLATES" = '~' ] then TEMPLATES_PAGE="NO-TEMPLATES" TEMPLATES_DYN="*" else TEMPLATES_PAGE="$TEMPLATES" TEMPLATES_DYN="$TEMPLATES" fi # CODE: cd $TPLS gen_news() { if [ ! -d NEWS/ ] then return 1 fi ls -1t NEWS/*.news | while read line do title=`echo "$line" | sed 's/.news$//; s#^NEWS/##;'` e=`echo "$title" | sed 's/[^a-zA-Z0-9]/_/g'` _t=`stat --format='%Z %U' "$line"` ctime=`echo "$_t" | cut -d' ' -f1` user=`echo "$_t" | cut -d' ' -f2` ctime_lr=`date --date "1970-01-01 00:00:00 UTC + ${ctime}sec"` echo "

$title

" echo "

$ctime_lr by $user

" echo "

" sed 's#^$#

#' < "$line" echo "

" done } gen_faq() { find FAQ/ -type d -not -wholename \*CVS\* | sed 's#^FAQ/##;' | grep -v ^$ | sort > "$OF.FAQCATS" find FAQ/ -type f -not -wholename \*CVS\* -and -name \*.faq | sed 's#^FAQ/##; s#\.faq$##' | sort > "$OF.FAQINDEX" echo echo "" [ -f ./-faq_eoh ] && cat "./-faq_eoh" while read cat do echo "

$cat

" echo grep "^$cat/" < "$OF.FAQINDEX" | \ while IFS='/' read dummy q do e=`echo "$q" | sed 's/[^a-zA-Z0-9]/_/g'` echo "

$q

" echo "

" sed 's#^$#

#' < "FAQ/$cat/$q.faq" echo "

" done done < "$OF.FAQCATS" echo } proc_page() { _tpl="$1" CLEANTPLNAME=$(echo "$_tpl" | sed 's/^[\-\+\~]//') OF="$OUT"/"$CLEANTPLNAME""$PAGE_SUFFIX" echo "Compiling $CLEANTPLNAME -> $OF" SECTIONS=`for _sec in $(grep --no-filename -- "^$_tpl[^a-zA-Z0-9-]" '#section-index'* | sed 's/^[^ \t]*[ \t]*[ \t]//'); do O=''; for i in $(tr . ' ' <<<"$_sec"); do O="$O.$i"; echo $O; done; done`' .ALL' # echo "Sections: $SECTIONS" SECTIONS_REGEX=$(for _sec in $SECTIONS; do echo "s/(section==$_sec:\([^)]*\):)/\1/g;"; done; echo "s/(section==.*:.*:)//g") MENU=$(grep --no-filename -- "^$_tpl[^a-zA-Z0-9-]" '#menu-index'* | sed 's/^[^ \t]*[ \t]*[ \t]//'); [ "$MENU" = '' ] && MENU="$DEFAULT_MENU" { cat -- -$HEADER cat -- "$MENU" cat -- -menu-mid cat -- $_tpl [ "$CLEANTPLNAME" = 'FAQ' ] && gen_faq [ "$CLEANTPLNAME" = 'NEWS' ] && gen_news cat -- -$END } | \ sed "$SECTIONS_REGEX" | \ # sed 's#href="+\(.*\)"#href="\1'"$PAGE_SUFFIX"'"#g' > $OF perl -pe's#href="\+(.+?)"#href="$1'"$PAGE_SUFFIX"'"#g' > $OF } for i in +$TEMPLATES_PAGE \~$TEMPLATES_DYN do [ -f "./$i" ] && proc_page "$i" done #ll