X-Git-Url: http://git.xonotic.org/?p=xonotic%2Fxonotic.git;a=blobdiff_plain;f=misc%2Ftools%2Fcached-converter.sh;h=ccbe0bb862a507b41b0b85d1cf905b0e5408d636;hp=f7fd47e2f398049c0ab7e3bcc1a2fe814e23275e;hb=b28f4b26d4a58308f988b838bb10621e1cc48a0b;hpb=32a3364b398bbacdb05b66c381a4fc79685b4e21 diff --git a/misc/tools/cached-converter.sh b/misc/tools/cached-converter.sh index f7fd47e2..ccbe0bb8 100755 --- a/misc/tools/cached-converter.sh +++ b/misc/tools/cached-converter.sh @@ -4,6 +4,7 @@ set -e : ${CACHEDIR:=$HOME/.xonotic-cached-converter} : ${do_jpeg:=true} +: ${do_jpeg_if_not_dds:=false} : ${jpeg_qual_rgb:=95} : ${jpeg_qual_a:=99} : ${do_dds:=true} @@ -128,8 +129,8 @@ reduce_rgba_jpeg2() i=$1; shift; shift o=$1; shift oa=$1; shift - convert "$i" -alpha extract -quality 100 "$o" && \ - convert "$i" -alpha off -quality 100 "$oa" && \ + convert "$i" -alpha off -quality 100 "$o" && \ + convert "$i" -alpha extract -quality 100 "$oa" && \ jpegoptim --strip-all -m"$1" "$o" && \ jpegoptim --strip-all -m"$2" "$oa" } @@ -165,21 +166,35 @@ has_alpha() to_delete= for F in "$@"; do + f=${F%.*} + echo >&2 "Handling $F..." conv=false keep=false + will_jpeg=$do_jpeg will_dds=$do_dds - case "$F" in - textures/*) ;; - models/*) ;; - maps/*/*) ;; + case "$f" in + ./models/player/*) will_dds=false ;; + ./textures/*) ;; + ./models/*) ;; + ./particles/*) ;; + ./progs/*) ;; *) # we can't DDS compress the 2D textures, sorry # but JPEG is still fine will_dds=false ;; esac + + if $do_jpeg_if_not_dds; then + if $will_dds; then + will_jpeg=false + else + will_jpeg=true + fi + fi + case "$F" in *_alpha.jpg) # handle in *.jpg case @@ -191,25 +206,23 @@ for F in "$@"; do keep=$will_jpeg ;; *.jpg) - if [ -f "${F%.jpg}_alpha.jpg" ]; then - 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" + if [ -f "${f}_alpha.jpg" ]; then + 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 "$will_dds" reduce_rgb_dds "$F" "" "dds/${F%.*}.dds" "" "$dds_flags" - cached "$will_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 "$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 + 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" else - 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 + cached "$will_dds" reduce_rgb_dds "$F" "" "dds/${f}.dds" "" "$dds_flags" + cached "$will_jpeg" reduce_rgb_jpeg "$F" "" "${f}.jpg" "" "$jpeg_qual_rgb" fi rm -f "$F.hasalpha" ;; @@ -228,6 +241,14 @@ for F in "$@"; do fi fi fi + # fix up DDS paths by a symbolic link + if [ -f "dds/${f}.dds" ]; then + if [ -z "${f##./textures/*}" ]; then + if [ -n "${f##./textures/*/*}" ]; then + ln -snf "textures/${f#./textures/}.dds" "dds/${f#./textures/}.dds" + fi + fi + fi done for F in $to_delete; do rm -f "$F"