X-Git-Url: http://git.plutz.net/?a=blobdiff_plain;f=list.sh;h=6245261026db7b75a44d5c3722c363b7b4bfd2f4;hb=dad9cd471358d165f1de2ce8d5806703ac85f5bb;hp=65d929a3204bd15967215b0729a9b2e8c6582a52;hpb=ccc8de4ebdd18fb52cdb8ce2013573d079186fba;p=serve0 diff --git a/list.sh b/list.sh index 65d929a..6245261 100755 --- a/list.sh +++ b/list.sh @@ -87,24 +87,14 @@ list_filter(){ } list_order(){ - local fm fn fn al length ln h w t c name buffer l + local fm fn fn al length ln h w t c name group o buffer l if [ $ORDER = Name ]; then sort -k6 elif [ $ORDER = Group ]; then - sed -E ' - /^[^\t]+\t[^\t]+\t[^\t]+\t[^\t]+\t[^\t]+\t[^\r]*\r$/bX; - /^[^\t]+\t[^\t]+\t[^\t]+\t[^\t]+\t[^\t]+\t[^\r]*\r\t\\$/bX; - s;^([^\t]+\t[^\t]+\t[^\t]+\t[^\t]+\t[^\t]+\t)([^\r]*)\r\t(.*)$;\1\r\3 \2\r\t;; - t; - :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;; - 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 w h t c name; do - if [ "${ln%% *}" = "${name%% *}" ]; then + { sort -n -k8 -k6,6 |sort -s -k7,7 ; echo '0 0 0 tags= comment= _'; } \ + | while read -r length w h t c name group o; do + if [ "${ln%% *}" = "${group}" ]; then al=$((al + length)) buffer="${buffer}${BR}$length $w $h $t $c $name" else @@ -114,13 +104,9 @@ list_order(){ al="$length" buffer="$length $w $h $t $c $name" fi - ln="$name" + ln="$group" done \ - | sort -s -n -k1,1 |sed -E 's;^[0-9]+\t;;;' \ - | sed -E ' - s;^([^\t]+\t[^\t]+\t[^\t]+\t[^\t]+\t[^\t]+\t)\r([0-9A-Za-z:=]{16}) ([^ ]+)$;\1\3\r\t\2;; t; - :X s;^([^\t]+\t[^\t]+\t[^\t]+\t[^\t]+\t[^\t]+\t[^\r]*)\r([^ ]*) ([^ ]+)( .*)?$;\1\3\2\4;; tX - ' + | sort -s -n -k1,1 |sed -E 's;^[0-9]+\t;;;' elif [ $ORDER = Length ]; then sort -sn -k1 elif [ $ORDER = Date ]; then