Index: tools/resources/optimize-png-files.sh |
diff --git a/tools/resources/optimize-png-files.sh b/tools/resources/optimize-png-files.sh |
index 351e04545e1735aaec7a50b2331db9aa231885f2..6f17c7c52a214287541cd71c8f58ca0d5e028a92 100755 |
--- a/tools/resources/optimize-png-files.sh |
+++ b/tools/resources/optimize-png-files.sh |
@@ -49,9 +49,18 @@ PROCESSED_FILE=0 |
declare -a THROBBER_STR=('-' '\\' '|' '/') |
THROBBER_COUNT=0 |
+SUBPROCESS=0 |
+ |
+# NoOp in subprocess, echo otherwise. |
+function info { |
+ if [ $SUBPROCESS -eq 0 ]; then |
+ echo $@ |
+ fi |
+} |
+ |
# Show throbber character at current cursor position. |
function throbber { |
- echo -ne "${THROBBER_STR[$THROBBER_COUNT]}\b" |
+ info -ne "${THROBBER_STR[$THROBBER_COUNT]}\b" |
let THROBBER_COUNT=($THROBBER_COUNT+1)%4 |
} |
@@ -92,7 +101,7 @@ function get_color_depth_list { |
# |
# TODO(oshima): Experiment with -d0 w/o -c0. |
function process_grayscale { |
- echo -n "|gray" |
+ info -n "|gray" |
for opt in $(get_color_depth_list); do |
pngout_loop $file -c0 $opt |
done |
@@ -101,7 +110,7 @@ function process_grayscale { |
# Usage: process_grayscale_alpha <file> |
# Optimize grayscale images with alpha for all color bit depths. |
function process_grayscale_alpha { |
- echo -n "|gray-a" |
+ info -n "|gray-a" |
pngout_loop $file -c4 |
for opt in $(get_color_depth_list); do |
pngout_loop $file -c3 $opt |
@@ -111,7 +120,7 @@ function process_grayscale_alpha { |
# Usage: process_rgb <file> |
# Optimize rgb images with or without alpha for all color bit depths. |
function process_rgb { |
- echo -n "|rgb" |
+ info -n "|rgb" |
for opt in $(get_color_depth_list); do |
pngout_loop $file -c3 $opt |
done |
@@ -123,7 +132,7 @@ function process_rgb { |
# Optimize the huffman blocks. |
function huffman_blocks { |
local file=$1 |
- echo -n "|huffman" |
+ info -n "|huffman" |
local size=$(stat -c%s $file) |
local min_block_size=$DEFAULT_MIN_BLOCK_SIZE |
local limit_blocks=$DEFAULT_LIMIT_BLOCKS |
@@ -149,7 +158,7 @@ function huffman_blocks { |
# TODO(oshima): Try adjusting different parameters for large files to |
# reduce runtime. |
function random_huffman_table_trial { |
- echo -n "|random" |
+ info -n "|random" |
local file=$1 |
local old_size=$(stat -c%s $file) |
local trials_count=$DEFAULT_RANDOM_TRIALS |
@@ -171,7 +180,7 @@ function random_huffman_table_trial { |
# Further compress using optipng and advdef. |
# TODO(oshima): Experiment with 256. |
function final_compression { |
- echo -n "|final" |
+ info -n "|final" |
local file=$1 |
if [ $OPTIMIZE_LEVEL == 2 ]; then |
for i in 32k 16k 8k 4k 2k 1k 512; do |
@@ -183,7 +192,7 @@ function final_compression { |
throbber |
advdef -q -z -$i $file |
done |
- echo -ne "\r" |
+ info -ne "\r" |
} |
# Usage: get_color_type <file> |
@@ -206,7 +215,7 @@ function get_color_type { |
function optimize_size { |
tput el |
local file=$1 |
- echo -n "$file " |
+ info -n "$file " |
advdef -q -z -4 $file |
@@ -225,7 +234,7 @@ function optimize_size { |
fi |
fi |
- echo -n "|filter" |
+ info -n "|filter" |
local old_color_type=$(get_color_type $file) |
optipng -q -zc9 -zm8 -zs0-3 -f0-5 $file -out $file.tmp.png |
local new_color_type=$(get_color_type $file.tmp.png) |
@@ -236,7 +245,7 @@ function optimize_size { |
# https://sourceforge.net/tracker/?func=detail&aid=3603630&group_id=151404&atid=780913 |
if [[ $old_color_type == "RGBA" && $new_color_type =~ gray.* ]] ; then |
rm $file.tmp.png |
- echo -n "[skip opting]" |
+ info -n "[skip opting]" |
else |
mv $file.tmp.png $file |
fi |
@@ -245,7 +254,7 @@ function optimize_size { |
huffman_blocks $file |
# TODO(oshima): Experiment with strategy 1. |
- echo -n "|strategy" |
+ info -n "|strategy" |
if [ $OPTIMIZE_LEVEL == 2 ]; then |
for i in 3 2 0; do |
pngout -q -k1 -ks -s$i $file |
@@ -300,7 +309,7 @@ function optimize_file { |
let PROCESSED_FILE+=1 |
else |
if [ $OPTIMIZE_LEVEL == 0 ]; then |
- echo -ne "$file : skipped\r" |
+ info -ne "$file : skipped\r" |
fi |
rm $tmp_file |
fi |
@@ -347,7 +356,7 @@ function fail_if_not_installed { |
function show_help { |
local program=$(basename $0) |
echo \ |
-"Usage: $program [options] dir ... |
+"Usage: $program [options] <dir> ... |
$program is a utility to reduce the size of png files by removing |
unnecessary chunks and compressing the image. |
@@ -364,6 +373,8 @@ Options: |
-r<revision> If this is specified, the script processes only png files |
changed since this revision. The <dir> options will be used |
to narrow down the files under specific directories. |
+ -s Run as subprocess. This may be used to parallelize execution. |
+ Usage: find <dir> -name \"*.png\" | xargs -n1 -P16 $program -s -o2 |
-h Print this help text." |
exit 1 |
} |
@@ -381,7 +392,7 @@ fi |
OPTIMIZE_LEVEL=1 |
# Parse options |
-while getopts o:r:h opts |
+while getopts o:r:h:s opts |
do |
case $opts in |
r) |
@@ -397,6 +408,9 @@ do |
fi |
OPTIMIZE_LEVEL=$OPTARG |
;; |
+ s) |
+ let SUBPROCESS=1 |
+ ;; |
[h?]) |
show_help;; |
esac |
@@ -437,7 +451,8 @@ trap "rm -rf $TMP_DIR" EXIT |
DIRS=$@ |
set ${DIRS:=$ALL_DIRS} |
-echo "Optimize level=$OPTIMIZE_LEVEL" |
+info "Optimize level=$OPTIMIZE_LEVEL" |
+ |
if [ -n "$COMMIT" ] ; then |
ALL_FILES=$(git diff --name-only $COMMIT HEAD $DIRS | grep "png$") |
ALL_FILES_LIST=( $ALL_FILES ) |
@@ -449,6 +464,10 @@ if [ -n "$COMMIT" ] ; then |
echo "Skipping deleted file: $f"; |
fi |
done |
+elif [ $SUBPROCESS -eq 1 ]; then |
+ for f in $DIRS; do |
+ optimize_file $f |
+ done |
else |
for d in $DIRS; do |
echo "Optimizing png files in $d" |
@@ -458,6 +477,10 @@ else |
fi |
# Print the results. |
+if [ $SUBPROCESS -eq 1 ]; then |
+ exit 0 |
+fi |
+ |
if [ $PROCESSED_FILE == 0 ]; then |
echo "Did not find any files (out of $TOTAL_FILE files)" \ |
"that could be optimized" \ |