X-Git-Url: https://git.xonotic.org/?p=xonotic%2Fxonotic.git;a=blobdiff_plain;f=misc%2Ftools%2Fcached-converter.sh;h=f7fd47e2f398049c0ab7e3bcc1a2fe814e23275e;hp=c500136ff86b6ebeefd62cc35d31aa2882677cee;hb=32a3364b398bbacdb05b66c381a4fc79685b4e21;hpb=6c1a97531688b91940383d3b492b37a2377b78b4 diff --git a/misc/tools/cached-converter.sh b/misc/tools/cached-converter.sh index c500136f..f7fd47e2 100755 --- a/misc/tools/cached-converter.sh +++ b/misc/tools/cached-converter.sh @@ -26,6 +26,8 @@ tmpdir=`mktemp -d -t cached-converter.XXXXXX` trap 'exit 1' INT trap 'rm -rf "$tmpdir"' EXIT +lastinfiles= +lastinfileshash= cached() { flag=$1; shift @@ -41,9 +43,14 @@ cached() keep=true fi options=`echo "$*" | git hash-object --stdin` - sum=`git hash-object "$infile1"` - if [ -n "$infile2" ]; then - sum=$sum`git hash-object "$infile2"` + if [ x"$infile1/../$infile2" = x"$lastinfiles" ]; then + sum=$lastinfileshash + else + sum=`git hash-object "$infile1"` + if [ -n "$infile2" ]; then + sum=$sum`git hash-object "$infile2"` + fi + lastinfileshash=$sum fi mkdir -p "$CACHEDIR/$method-$options" name1="$CACHEDIR/$method-$options/$sum-1.${outfile1##*.}" @@ -93,7 +100,7 @@ reduce_jpeg_jpeg() cp "$i" "$o" && jpegoptim --strip-all -m"$1" "$o" } -reduce_ogg() +reduce_ogg_ogg() { i=$1; shift; shift o=$1; shift; shift @@ -101,6 +108,13 @@ reduce_ogg() oggenc -q"$1" -o "$o" "$tmpdir/x.wav" } +reduce_wav_ogg() +{ + i=$1; shift; shift + o=$1; shift; shift + oggenc -q"$1" -o "$o" "$i" +} + reduce_rgba_dds() { i=$1; shift; shift @@ -149,50 +163,72 @@ has_alpha() fi } +to_delete= for F in "$@"; do echo >&2 "Handling $F..." conv=false keep=false + will_jpeg=$do_jpeg + will_dds=$do_dds + case "$F" in + textures/*) ;; + models/*) ;; + maps/*/*) ;; + *) + # we can't DDS compress the 2D textures, sorry + # but JPEG is still fine + will_dds=false + ;; + esac case "$F" in *_alpha.jpg) # handle in *.jpg case # they always got converted, I assume - conv=true - keep=$do_jpeg + if $will_dds || $will_jpeg; then + conv=true + fi + keep=$will_jpeg ;; *.jpg) if [ -f "${F%.jpg}_alpha.jpg" ]; then - cached "$do_dds" reduce_jpeg2_dds "$F" "${F%.*}_alpha.jpg" "dds/${F%.*}.dds" "" "$dds_flags" - cached "$do_jpeg" reduce_jpeg2_jpeg2 "$F" "${F%.*}_alpha.jpg" "$F" "${F%.*}_alpha.jpg" "$jpeg_qual_rgb" "$jpeg_qual_a" + cached "$will_dds" reduce_jpeg2_dds "$F" "${F%.*}_alpha.jpg" "dds/${F%.*}.dds" "" "$dds_flags" + cached "$will_jpeg" reduce_jpeg2_jpeg2 "$F" "${F%.*}_alpha.jpg" "$F" "${F%.*}_alpha.jpg" "$jpeg_qual_rgb" "$jpeg_qual_a" else - cached "$do_dds" reduce_rgb_dds "$F" "" "dds/${F%.*}.dds" "" "$dds_flags" - cached "$do_jpeg" reduce_jpeg_jpeg "$F" "" "$F" "" "$jpeg_qual_rgb" + cached "$will_dds" reduce_rgb_dds "$F" "" "dds/${F%.*}.dds" "" "$dds_flags" + cached "$will_jpeg" reduce_jpeg_jpeg "$F" "" "$F" "" "$jpeg_qual_rgb" fi ;; *.png|*.tga) cached true has_alpha "$F" "" "$F.hasalpha" "" conv=false if [ -s "$F.hasalpha" ]; then - cached "$do_dds" reduce_rgba_dds "$F" "" "dds/${F%.*}.dds" "" "$dds_flags" - cached "$do_jpeg" reduce_rgba_jpeg2 "$F" "" "${F%.*}.jpg" "${F%.*}_alpha.jpg" "$jpeg_qual_rgb" "$jpeg_qual_a" + cached "$will_dds" reduce_rgba_dds "$F" "" "dds/${F%.*}.dds" "" "$dds_flags" + cached "$will_jpeg" reduce_rgba_jpeg2 "$F" "" "${F%.*}.jpg" "${F%.*}_alpha.jpg" "$jpeg_qual_rgb" "$jpeg_qual_a" rm -f "$F" # TGA becomes useless after JPEGging else - cached "$do_dds" reduce_rgb_dds "$F" "" "dds/${F%.*}.dds" "" "$dds_flags" - cached "$do_jpeg" reduce_rgb_jpeg "$F" "" "${F%.*}.jpg" "" "$jpeg_qual_rgb" + cached "$will_dds" reduce_rgb_dds "$F" "" "dds/${F%.*}.dds" "" "$dds_flags" + cached "$will_jpeg" reduce_rgb_jpeg "$F" "" "${F%.*}.jpg" "" "$jpeg_qual_rgb" rm -f "$F" # TGA becomes useless after JPEGging fi rm -f "$F.hasalpha" ;; *.ogg) - cached "$do_ogg" reduce_ogg "$F" "" "$F" "" "$ogg_qual" + cached "$do_ogg" reduce_ogg_ogg "$F" "" "$F" "" "$ogg_qual" + ;; + *.wav) + cached "$do_ogg" reduce_wav_ogg "$F" "" "$F" "" "$ogg_qual" ;; esac if $del_src; then if $conv; then if ! $keep; then - rm -f "$F" + # FIXME can't have spaces in filenames that way + to_delete="$to_delete $F" fi fi fi done +for F in $to_delete; do + rm -f "$F" +done