X-Git-Url: http://git.plutz.net/?a=blobdiff_plain;f=list.sh;h=2dc1a8340307a7ca0f09f4d26c74d45b975d1ba8;hb=7b674b9084ef483caee686be6cc051920eae2a70;hp=607ea201ed6580ef2a0d5087c72860600669708c;hpb=ee2a0b2dc2a7a72f6c7cb16fa5108c5597637e7d;p=serve0 diff --git a/list.sh b/list.sh index 607ea20..2dc1a83 100644 --- a/list.sh +++ b/list.sh @@ -6,12 +6,12 @@ list_item() { local name path length width height tags comment n name="$(HTML "$1")" - path="$(HTML "$ITEM/$1")" + path="$(URL "$ITEM/$1")" + qry=$(HTML "$QUERY_STRING") if [ -d "$_DATA/$ITEM/$1" ]; then - printf '[a .list .dir href="%s?%s" %s]' \ - "$path" "$(HTML "$QUERY_STRING")" "$name" - else + printf '[a .list .dir href="%s" %s]' "${path}?${qry}" "$name" + elif [ -f "$_DATA/$ITEM/$1" ]; then read -r length width height tags comment n <<-EOF $(meta_info "$_DATA/$ITEM/$1") EOF @@ -25,6 +25,9 @@ list_item() { "$width" "$height" \ "$(UNSTRING "${tags#tags=}" |tr , '\0' |xargs -r0 printf ' [span .tag %s]')" \ "$path" "$path" "$path" + else + printf 'Canning record for nonexist file: %s\n' "$1" >&2 + meta_purge "$_DATA/$ITEM/$1" fi } @@ -34,20 +37,51 @@ list_directories(){ ) | cut -d/ -f2- | sort } +[ "$FILTER" ] && list_fex="$( + fex='p' + STRING "$FILTER^" \ + | sed -r 's;\^;\n;g; s;[]\/\(\)\\\^\$\?\.\+\*\;\[\{\}];\\&;g' \ + | while read -r f; do + [ ! "${f#~}" ] && continue + [ "${f#~}" = "$f" ] \ + && fex="/(\ttags=([^\t]*,)?)(${f})((,[^\t]*)?\t)/{${fex}}" \ + || fex="/(\ttags=([^\t]*,)?)(${f#~})((,[^\t]*)?\t)/d; ${fex}" + printf '%s\n' "${fex}" + done \ + | tail -n1 +)" + +list_fullname(){ + sn="$1" + [ ! "${sn%%*/*}" ] && base="${sn%/*}" || base=. + file="$(printf '%s' "$_DATA/$ITEM/$sn".*)" + file="${file##*/}" + [ -e "$_DATA/$ITEM/$base/${file}" ] \ + && printf '%s\n' "${base}/${file}" +} + list_filemeta(){ local meta base f fn file base="$1" - meta="$1/.index/meta" + meta="$_DATA/$ITEM/$base/.index/meta" meta_dir "$_DATA/$ITEM/$base" - grep -iE "$(STRING "${SEARCH}")" "$_DATA/$ITEM/$meta" \ - | cut -f1,6- \ - | while f="$(line)"; do - fn="$(UNSTRING "${f#* }")"; fn="${fn%${CR}}"; - file="$(printf '%s\n' "$_DATA/$ITEM/$base/${fn}".*)" - file="${file##*/}" - [ -e "$_DATA/$ITEM/$base/${file}" ] \ - && printf '%s %s\n' "${f%% *}" "${base}/${file}" + if [ $ORDER = Name ]; then + sort -k6 "$meta" + elif [ $ORDER = Length ]; then + sort -n "$meta" + else + cat "$meta" + fi \ + | if [ "$FILTER" ]; then + sed -nr "$list_fex" + elif [ "${SEARCH#!}" != "${SEARCH}" ]; then + grep -viE "$(STRING "${SEARCH#!}")" + else + grep -iE "$(STRING "${SEARCH}")" + fi |cut -f6 | UNSTRING \ + | while read -r fn; do + printf '%s\n' "${base}/${fn%${CR}}" done } @@ -55,11 +89,20 @@ list_index(){ local meta (cd "$_DATA/$ITEM"; find ./ -path '*/.index/meta' - ) | while meta="$(line)"; do + ) | while read -r meta; do list_filemeta "${meta%/.index/meta}" done } +list_dateorder(){ + while read -r sn; do + list_fullname "$sn" + done \ + | xargs -rd'\n' stat -c '%Y %n' \ + | sort -rn |cut -d/ -f2- \ + | sed -r 's;\.[^\.]*$;;;' +} + list_items() { local mode mode="$(COOKIE mode |grep -m1 -xE 'index|browse' || printf browse )" @@ -68,76 +111,66 @@ list_items() { if [ "$mode" = browse -a "$ORDER" = Date ]; then list_directories - list_filemeta . |cut -f2- \ - | xargs -d\n stat -c '%Y %n' \ - | sort -rn |cut -d/ -f2- - elif [ "$mode" = browse -a "$ORDER" = Name ]; then - list_directories - list_filemeta . \ - | sort -k 2 |cut -d/ -f2- + list_filemeta . |list_dateorder elif [ "$mode" = index -a "$ORDER" = Date ]; then - list_index |cut -f2- \ - | xargs -d'\n' stat -c '%Y %n' \ - | sort -rn | cut -d/ -f2- - elif [ "$mode" = index -a "$ORDER" = Name ]; then - list_index | sort -k 2 | cut -d/ -f2- - elif [ "$mode" = browse -a "$ORDER" = Length ]; then + list_index |list_dateorder + elif [ "$mode" = browse ]; then list_directories - list_filemeta . \ - | sort -n |cut -d/ -f2- - elif [ "$mode" = index -a "$ORDER" = Length ]; then - list_index \ - | sort -n |cut -d/ -f2- + list_filemeta . + elif [ "$mode" = index ]; then + list_index fi } list_paginate() { - local page i c n - page="$(GET p |grep -xE '[0-9]+' || printf 1)" + local page i c n end + page="$(GET p |grep -xE '[0-9]+' || printf 1)"; c=1 + end=$((page + LISTSIZE)) printf '[div .itemlist ' - while i="$(line)"; do - c=$((${c-0} + 1)) - if [ $c -lt $page ]; then - true - elif [ $c -lt $((LISTSIZE + page)) ]; then - list_item "$i" - fi + while read -r i; do + [ $c -ge $page -a $c -lt $end ] \ + && list_item "$(list_fullname "$i")" + c=$((c + 1)) done printf ']' printf '[div .pagination' - for n in $(seq 1 $((c / LISTSIZE + 1)) ); do + for n in $( seq 1 $((c / LISTSIZE + 1)) ); do printf '[a .page href="%s" %s]' \ - "?p=$(( (n - 1) * LISTSIZE + 1))" "$n" + "?p=$(( (n - 1) * LISTSIZE + 1))&$qry" "$n" done printf ']' } printf 'Content-Type: text/html;charset=utf-8\r\n\r\n' -"$_EXEC/cgilite/html-sh.sed" <<-EOF +{ printf ' [!DOCTYPE HTML] [html [head [title Listing] + [meta name="viewport" content="width=device-width"] [link rel=stylesheet href="/style.css" ] ] [body [div #navigation - [a #t_bookmarks href="#bookmarks" ★] - $(w_search) + [a #t_bookmarks href="#bookmarks" ★]' + w_search + printf ' [a #t_avsearch href="#advsearch" Advanced] [a #t_prefs href="#prefs" ⚙] - ] - $(w_prefs) - - [form method=POST action="?a=multitag" - $(list_items \ - | list_paginate - ) + ]' + w_prefs + w_advsearch + printf ' + [form method=POST action="?a=multitag"' + list_items \ + | list_paginate + printf ' [div #editing - [a href="#multitag" Add Tags] $(w_tagging) - $(w_index) + [a href="#multitag" Add Tags]' + w_tagging + w_index + printf ' ] ] ] ] -EOF - +'; } | "$_EXEC/cgilite/html-sh.sed"