X-Git-Url: http://git.plutz.net/?a=blobdiff_plain;f=list.sh;h=8ba460e066388c267eb53ae16b2df95341ac04d0;hb=59e9e99551eb5889b1efa077c8b2ffa97c2eccf9;hp=e9a98c0ecf8e75d8a338c8d06350d612568edaf9;hpb=b3e752c8f50110859bc9e3aaf9d709e2006b3de6;p=serve0 diff --git a/list.sh b/list.sh index e9a98c0..8ba460e 100644 --- a/list.sh +++ b/list.sh @@ -49,12 +49,12 @@ list_item() { [ "$FILTER" ] && list_fex="$( fex='p' STRING "$FILTER^" \ - | sed -r 's;\^;\n;g; s;[]\/\(\)\\\^\$\?\.\+\*\;\[\{\}];\\&;g' \ + | sed -E 's;\^;\n;g; s;[]\/\(\)\\\^\$\?\.\+\*\;\[\{\}];\\&;g' \ | while read -r f; do - [ ! "${f#~}" ] && continue - [ "${f#~}" = "$f" ] \ + [ "${f#\~}" ] || continue + [ "${f#\~}" = "$f" ] \ && fex="/(\ttags=([^\t]*,)?)(${f})((,[^\t]*)?\t)/{${fex}}" \ - || fex="/(\ttags=([^\t]*,)?)(${f#~})((,[^\t]*)?\t)/d; ${fex}" + || fex="/(\ttags=([^\t]*,)?)(${f#\~})((,[^\t]*)?\t)/d; ${fex}" printf '%s\n' "${fex}" done \ | tail -n1 @@ -71,15 +71,16 @@ list_fullname(){ list_filter(){ if [ "$FILTER" ]; then - sed -nr "$list_fex" + printf "FEX: %s\n" "$list_fex" >&2 + sed -nE "$list_fex" elif [ "${SEARCH#!}" != "${SEARCH}" ]; then grep -aviEe "$(STRING "${SEARCH}" \ - | sed -r ':x s;((^|[^\\])(\\\\)*)\+;\1 ;g; tx; + | sed -E ':x s;((^|[^\\])(\\\\)*)\+;\1 ;g; tx; s;((^|[^\\])(\\\\)*)\\\+;\1+;g; s; ;\\+;g;')" elif [ "${SEARCH}" ]; then grep -aiEe "$(STRING "${SEARCH}" \ - | sed -r ':x s;((^|[^\\])(\\\\)*)\+;\1 ;g; tx; + | sed -E ':x s;((^|[^\\])(\\\\)*)\+;\1 ;g; tx; s;((^|[^\\])(\\\\)*)\\\+;\1+;g; s; ;\\+;g;')" else @@ -88,12 +89,35 @@ list_filter(){ } list_order(){ - local fm fn fn + local fm fn fn al length ln h w t c name buffer l if [ $ORDER = Name ]; then sort -k6 |sed 's;^;metashort\t;;' + elif [ $ORDER = Group ]; then + sed -E ' + :X + s;^([^\t]+\t[^\t]+\t[^\t]+\t[^\t]+\t[^\t]+\t[^ 0-9]*)-([0-9a-zA-Z_-]{11}\r|ph[0-9a-f]{13}\r|[0-9]{8}\r)(.*)$;\1-\r\3 \2\n;; + t; + s;^([^\t]+\t[^\t]+\t[^\t]+\t[^\t]+\t[^\t]+\t[^ 0-9]*)([0-9]+)(.*)$;\1\r\3 \2;; + tX;' \ + | { sort -n -k7 -k8 -k9 -k10 -k11 |sort -s -k6,6 ; echo '0 0 0 tags= comment= _'; } \ + | while read -r length h w t c name; do + if [ "${ln%% *}" = "${name%% *}" ]; then + al=$((al + length)) + buffer="${buffer}${BR}$length $h $w $t $c $name" + else + printf '%s\n' "$buffer" |while read -r l; do + [ "$l" ] && printf '%s %s\n' "$al" "$l" + done + al="$length" + buffer="$length $h $w $t $c $name" + fi + ln="$name" + done \ + | sort -s -n -k1,1 |sed -E 's;^[0-9]+\t;metashort\t;;' \ + | sed -E ':X s;^([^\t]+\t[^\t]+\t[^\t]+\t[^\t]+\t[^\t]+\t[^\r]*)\r([^ ]*) ([^ ]+)( .*)?$;\1\3\2\4;; tX' elif [ $ORDER = Length ]; then - sort -n -k1 |sed 's;^;metashort\t;;' + sort -sn -k1 |sed 's;^;metashort\t;;' elif [ $ORDER = Date ]; then while read -r fm; do sn="${fm##* }" @@ -101,7 +125,7 @@ list_order(){ printf '%i %s %s\n' \ "$(stat -c %Y "$fn")" "${fm% *}" "$fn" done \ - | sort -rn -k1 |cut -f2- |sed 's;^;metalong\t;;' + | sort -srn -k1 |sed -E 's;^[0-9]+\t;metalong\t;;' fi } @@ -130,7 +154,7 @@ list_filemeta(){ list_items() { local mode meta - mode="$(COOKIE mode |grep -m1 -axE 'index|browse' || printf browse )" + mode="$(COOKIE mode |grep -m1 -axE 'index|browse' || printf index )" if [ "$mode" = browse ]; then [ "$ITEM" ] && printf 'dir\t..\n' @@ -178,7 +202,10 @@ printf 'Content-Type: text/html;charset=utf-8\r\n\r\n' { printf ' [!DOCTYPE HTML] -[html [head [title Listing] +[html [head [title ' + w_bmname + printf ' by %s]' "$ORDER" + printf ' [meta name="viewport" content="width=device-width"] [link rel=stylesheet href="/style.css" ] ] [body