X-Git-Url: https://git.xonotic.org/?p=xonotic%2Fxonotic.git;a=blobdiff_plain;f=misc%2Ftools%2Fcached-converter.sh;h=b4fafee88ca1d7dc23e6f1ea26ec649ddeb86e7e;hp=77a4703c2147ecf6557c8a814830970dd84e86ec;hb=c6b9c744e52329d5f21d4afc47ef50cc12460648;hpb=f872318f69e8a0b49b53157ba70ce5ccbd95fb15 diff --git a/misc/tools/cached-converter.sh b/misc/tools/cached-converter.sh index 77a4703c..b4fafee8 100755 --- a/misc/tools/cached-converter.sh +++ b/misc/tools/cached-converter.sh @@ -7,10 +7,17 @@ set -e : ${do_jpeg_if_not_dds:=false} : ${jpeg_qual_rgb:=95} : ${jpeg_qual_a:=99} +: ${do_webp:=false} +: ${do_webp_if_not_dds:=false} +: ${webp_flags_lq:=-lossless -q 100} +: ${webp_flags_hq:=-lossless -q 100} +: ${webp_flags_alq:=-lossless -q 100 -q_alpha 100} +: ${webp_flags_ahq:=-lossless -q 100 -q_alpha 100} : ${do_dds:=true} : ${dds_tool:=compressonator-dxtc} : ${do_ogg:=false} -: ${ogg_qual:=1} +: ${ogg_ogg:=true} +: ${ogg_qual:=2} : ${del_src:=false} : ${git_src_repo:=} : ${dds_noalpha:=dxt1} @@ -66,9 +73,9 @@ use_magnet_to_acquire_checksum_faster() if [ -n "$magnet" ]; then magnet=${magnet#* } magnet=${magnet%% *} - sum=$sum$magnet + echo "$magnet" else - sum=$sum`git hash-object "$1"` + git hash-object "$1" fi } @@ -88,10 +95,9 @@ acquire_checksum() esac done if [ -n "$git_src_repo" ] && ! $_a_e; then - _a_s= - use_magnet_to_acquire_checksum_faster "${1#./}" + _a_s=`use_magnet_to_acquire_checksum_faster "${1#./}"` if [ -n "$2" ]; then - use_magnet_to_acquire_checksum_faster "${2#./}" + _a_s=$_a_s`use_magnet_to_acquire_checksum_faster "${2#./}"` fi else _a_s=`git hash-object "$1"` @@ -204,7 +210,7 @@ reduce_jpeg2_dds() i=$1; shift ia=$1; shift o=$1; shift; shift - convert "$i" "$ia" -compose CopyOpacity -composite "$tmpdir/x.tga" && \ + convert "$i" "$ia" -compose CopyOpacity -composite -type TrueColorMatte "$tmpdir/x.tga" && \ pickdxta "$dds_tool" "$dds_sepalpha" "$tmpdir/x.tga" "$o" $1 } @@ -213,7 +219,7 @@ reduce_jpeg2_dds_premul() i=$1; shift ia=$1; shift o=$1; shift; shift - convert "$i" "$ia" -compose CopyOpacity -composite "$tmpdir/x.tga" && \ + convert "$i" "$ia" -compose CopyOpacity -composite -type TrueColorMatte "$tmpdir/x.tga" && \ pickdxta "$dds_tool" "$dds_prealpha" "$tmpdir/x.tga" "$o" $1 } @@ -239,6 +245,16 @@ reduce_jpeg2_jpeg2() fi } +reduce_jpeg2_webp() +{ + i=$1; shift + ia=$1; shift + o=$1; shift; shift + # this one MUST run + convert "$i" "$ia" -compose CopyOpacity -composite -type TrueColorMatte "$tmpdir/x.png" && \ + cwebp $1 "$tmpdir/x.png" -o "$o" +} + reduce_jpeg_jpeg() { i=$1; shift; shift @@ -273,7 +289,7 @@ reduce_rgba_dds() { i=$1; shift; shift o=$1; shift; shift - convert "$i" "$tmpdir/x.tga" && \ + convert "$i" -type TrueColorMatte "$tmpdir/x.tga" && \ pickdxta "$dds_tool" "$dds_sepalpha" "$tmpdir/x.tga" "$o" $1 } @@ -281,7 +297,7 @@ reduce_rgba_dds_premul() { i=$1; shift; shift o=$1; shift; shift - convert "$i" "$tmpdir/x.tga" && \ + convert "$i" -type TrueColorMatte "$tmpdir/x.tga" && \ pickdxta "$dds_tool" "$dds_prealpha" "$tmpdir/x.tga" "$o" $1 } @@ -306,7 +322,7 @@ reduce_rgb_dds() { i=$1; shift; shift o=$1; shift; shift - convert "$i" "$tmpdir/x.tga" && \ + convert "$i" -type TrueColor "$tmpdir/x.tga" && \ "$meprefix"compress-texture "$dds_tool" "$dds_noalpha" "$tmpdir/x.tga" "$o" $1 } @@ -321,6 +337,14 @@ reduce_rgb_jpeg() fi } +reduce_rgba_webp() +{ + i=$1; shift; shift + o=$1; shift; shift + convert "$i" "$tmpdir/x.png" && \ + cwebp $1 "$tmpdir/x.png" -o "$o" +} + has_alpha() { i=$1; shift; shift @@ -344,15 +368,23 @@ for F in "$@"; do keep=false jqual_rgb=$jpeg_qual_rgb jqual_a=$jpeg_qual_a + webp_mode=lq will_jpeg=$do_jpeg + will_webp=$do_webp will_dds=$do_dds will_ogg=$do_ogg + if ! $ogg_ogg; then + case "$f" in + *.ogg) will_ogg=false ;; + esac + fi case "$f" in ./sounds/misc/talk*.wav) will_ogg=false ;; # engine "feature" *_bump) will_dds=false ;; ./models/player/*) will_dds=false ;; ./models/sprites/*) will_dds=false ;; + ./models/*) ;; ./textures/*) ;; ./models/*) ;; ./particles/*) ;; @@ -383,12 +415,15 @@ for F in "$@"; do case "$f" in ./maps/*/lm_[0-9][0-9][0-9][13579]) # deluxemap jqual_rgb=$jqual_a + webp_mode=hq ;; ./maps/*/lm_[0-9][0-9][0-9][02468]) # lightmap jqual_rgb=$jqual_a + webp_mode=hq ;; *_norm) # normalmap jqual_rgb=$jqual_a + webp_mode=hq ;; esac fi @@ -407,13 +442,20 @@ for F in "$@"; do will_jpeg=true fi fi + if $do_webp_if_not_dds; then + if $will_dds; then + will_webp=false + else + will_webp=true + fi + fi selfprofile startconvert case "$F" in *_alpha.jpg) # handle in *.jpg case # they always got converted, I assume - if $will_dds || $will_jpeg; then + if $will_dds || $will_jpeg || $will_webp; then conv=true fi keep=$will_jpeg @@ -422,20 +464,28 @@ for F in "$@"; do if [ -f "${f}_alpha.jpg" ]; then cached "$will_dds" reduce_jpeg2_dds$pm "$F" "${f}_alpha.jpg" "dds/${f}.dds" "" "$dds_flags" cached "$will_jpeg" reduce_jpeg2_jpeg2 "$F" "${f}_alpha.jpg" "$F" "${f}_alpha.jpg" "$jqual_rgb" "$jqual_a" - else + #eval wflags=\$webp_flags_${webp_mode}a + #cached "$will_webp" reduce_jpeg2_webp "$F" "${f}_alpha.jpg" "${f}.webp" "" "$wflags" + else cached "$will_dds" reduce_rgb_dds "$F" "" "dds/${f}.dds" "" "$dds_flags" cached "$will_jpeg" reduce_jpeg_jpeg "$F" "" "$F" "" "$jqual_rgb" + #eval wflags=\$webp_flags_${webp_mode} + #cached "$will_webp" reduce_rgba_webp "$F" "" "${f}.webp" "" "$wflags" fi ;; - *.png|*.tga) + *.png|*.tga|*.webp) cached true has_alpha "$F" "" "$F.hasalpha" "" conv=false if [ -s "$F.hasalpha" ]; then cached "$will_dds" reduce_rgba_dds$pm "$F" "" "dds/${f}.dds" "" "$dds_flags" cached "$will_jpeg" reduce_rgba_jpeg2 "$F" "" "${f}.jpg" "${f}_alpha.jpg" "$jqual_rgb" "$jqual_a" - else + eval wflags=\$webp_flags_${webp_mode}a + cached "$will_webp" reduce_rgba_webp "$F" "" "${f}.webp" "" "$wflags" + else cached "$will_dds" reduce_rgb_dds "$F" "" "dds/${f}.dds" "" "$dds_flags" cached "$will_jpeg" reduce_rgb_jpeg "$F" "" "${f}.jpg" "" "$jqual_rgb" + eval wflags=\$webp_flags_${webp_mode} + cached "$will_webp" reduce_rgba_webp "$F" "" "${f}.webp" "" "$wflags" fi rm -f "$F.hasalpha" ;;