X-Git-Url: http://git.plutz.net/?a=blobdiff_plain;f=multitag.sh;h=45798069f237adfab581e7bcbe7b9034de3168d2;hb=0bca0bee961be0c55bddba41b28501d014aef4a6;hp=43484e63fb9e28698f15258ca4a841992ddf9427;hpb=f99cce3548251966cd0b7c9ead81460e2f14466c;p=serve0 diff --git a/multitag.sh b/multitag.sh index 43484e6..4579806 100644 --- a/multitag.sh +++ b/multitag.sh @@ -1,35 +1,35 @@ #!/bin/sh +. "$_EXEC/cgilite/storage.sh" +. "$_EXEC/indexmeta.sh" + +newtags='' +for tn in $(seq 1 $(POST_COUNT tag)); do + newtags="${newtags},$(POST tag $tn)" +done +newtags="${newtags},$(POST newtag |tr -d '\r')" + for select in $(seq 1 $(POST_COUNT select)); do - file="$_DATA/$ITEM/$(POST select $select)" + file="$_DATA/$ITEM/$(POST select $select |PATH)" meta="${file%/*}/.index/meta" - fn="${file##*/}" - - while ! mkdir "${meta}.lock"; do - sleep 1 - ps -o pid \ - | grep -q "$(cat "${meta}.lock/pid")" \ - || break - done - printf '%i\n' >"${meta}.lock/pid" - - grep -vF " $fn" "$meta" >"${meta}.lock/mtmp" - read length width height tags comment x <<-EOF - $(grep -F " $fn" "$meta") + + read -r length width height tags comment fn <<-EOF + $(meta_info "$file") EOF - tags="$(printf '%s' "${tags#tags=}" | tr , '\n')" - for tn in $(seq 1 $(POST_COUNT tag)); do - tags="$tags${BR}$(POST tag $tn |sed -r 's;\t;\\t;g; s;\r;;g;')" - done - tags="$tags${BR}$(POST newtag |sed -r 's;\t;\\t;g;')" + tags="$(UNSTRING "${tags#tags=}")" + tags="$(printf '%s\n' "${tags}" "${newtags}" |tr , '\n' |sort -u |tr '\n' , |STRING)" + tags="${tags#,}"; tags="${tags%,}" + + if LOCK "$meta"; then + grep -avF " $fn" "$meta" >"${meta}.tmp" - printf '%s\t%s\t%s\ttags=%s\t%s\t%s\n' \ - "$length" "$width" "$height" \ - "$(printf %s "$tags" |sort -u |tr '\n' ,)" \ - "$comment" "$fn" \ - >>"${meta}.lock/mtmp" - mv "${meta}.lock/mtmp" "$meta" + printf '%i %i %i tags=%s comment=%s %s\n' \ + "$length" "$width" "$height" "$tags" \ + "${comment#comment=}" "$fn" \ + >>"${meta}.tmp" + mv "${meta}.tmp" "$meta" - rm "${meta}.lock/pid"; rmdir "${meta}.lock" + RELEASE "$meta" + fi done