mirror of
https://github.com/libjpeg-turbo/libjpeg-turbo
synced 2025-03-28 21:13:18 +00:00
173 lines
4.4 KiB
Plaintext
Executable File
173 lines
4.4 KiB
Plaintext
Executable File
#/bin/bash
|
|
|
|
set -u
|
|
set -e
|
|
trap onexit INT
|
|
trap onexit TERM
|
|
trap onexit EXIT
|
|
|
|
onexit()
|
|
{
|
|
if [ -d $OUTDIR ]; then
|
|
rm -rf $OUTDIR
|
|
fi
|
|
}
|
|
|
|
runme()
|
|
{
|
|
echo \*\*\* $* | sed "s@$EXEDIR@\$EXEDIR@g" | sed "s@$IMGDIR@\$IMGDIR@g" |
|
|
sed "s@$JAVA@\$JAVA@g" | sed "s@$OUTDIR@\$OUTDIR@g"
|
|
"$@"
|
|
}
|
|
|
|
IMGDIR=@CMAKE_SOURCE_DIR@/testimages
|
|
OUTDIR=`mktemp -d /tmp/__tjtrantest_output.XXXXXX`
|
|
EXEDIR=@CMAKE_BINARY_DIR@
|
|
JAVA="@Java_JAVA_EXECUTABLE@"
|
|
JAVAARGS="-cp $EXEDIR/java/turbojpeg.jar -Djava.library.path=$EXEDIR"
|
|
TJTRAN=$EXEDIR/tjtran
|
|
JAVAARG=
|
|
|
|
if [ -d $OUTDIR ]; then
|
|
rm -rf $OUTDIR
|
|
fi
|
|
mkdir -p $OUTDIR
|
|
|
|
while [ $# -gt 0 ]; do
|
|
case "$1" in
|
|
-java)
|
|
JAVAARG=-java
|
|
TJTRAN="$JAVA $JAVAARGS TJTran"
|
|
;;
|
|
esac
|
|
shift
|
|
done
|
|
|
|
exec >$EXEDIR/test/tjtrantest$JAVAARG.log
|
|
|
|
echo "EXEDIR: $EXEDIR"
|
|
echo "IMGDIR: $IMGDIR"
|
|
echo "OUTDIR: $OUTDIR"
|
|
echo
|
|
|
|
SUBSAMPOPT=(444 422 440 420 411 441 410)
|
|
SAMPOPT=(1x1 2x1 1x2 2x2 4x1 1x4 4x2)
|
|
|
|
for precision in 8 12; do
|
|
if [ $precision -le 8 ]; then
|
|
RGBIMG=$IMGDIR/testorig.ppm
|
|
GRAYIMG=$IMGDIR/testorig.pgm
|
|
else
|
|
RGBIMG=$IMGDIR/monkey16.ppm
|
|
GRAYIMG=$IMGDIR/monkey16.pgm
|
|
fi
|
|
|
|
for sampi in {0..6}; do
|
|
EXTRA_ARGS=
|
|
if [ $sampi = 1 ]; then
|
|
EXTRA_ARGS=-p
|
|
elif [ $sampi = 2 ]; then
|
|
EXTRA_ARGS=-a
|
|
elif [ $sampi = 3 ]; then
|
|
EXTRA_ARGS="-o -icc $IMGDIR/test1.icc"
|
|
elif [ $sampi = 5 ]; then
|
|
EXTRA_ARGS="-r 1"
|
|
fi
|
|
runme $EXEDIR/cjpeg -pre $precision -sa ${SAMPOPT[$sampi]} $EXTRA_ARGS \
|
|
-outf $OUTDIR/`basename $RGBIMG .ppm`-${SUBSAMPOPT[$sampi]}.jpg $RGBIMG
|
|
if [[ $sampi = 3 || $sampi = 4 ]]; then
|
|
$EXEDIR/wrjpgcom -comment "This is a test" \
|
|
$OUTDIR/`basename $RGBIMG .ppm`-${SUBSAMPOPT[$sampi]}.jpg \
|
|
>$OUTDIR/temp.jpg
|
|
mv $OUTDIR/temp.jpg \
|
|
$OUTDIR/`basename $RGBIMG .ppm`-${SUBSAMPOPT[$sampi]}.jpg
|
|
fi
|
|
done
|
|
runme $EXEDIR/cjpeg -pre $precision \
|
|
-outf $OUTDIR/`basename $GRAYIMG .pgm`-gray.jpg $GRAYIMG
|
|
echo
|
|
|
|
for subsamp in ${SUBSAMPOPT[*]} gray; do
|
|
if [ "$subsamp" = "gray" ]; then
|
|
basename=`basename $GRAYIMG .pgm`
|
|
else
|
|
basename=`basename $RGBIMG .ppm`
|
|
fi
|
|
for ariarg in "" "-a"; do
|
|
for copyarg in "" "-c i" "-c n"; do
|
|
if [[ "$copyarg" = "-c n" && "$subsamp" != "411" && \
|
|
"$subsamp" != "420" ]]; then
|
|
continue
|
|
fi
|
|
if [[ "$copyarg" = "-c i" && "$subsamp" != "420" ]]; then
|
|
continue
|
|
fi
|
|
for croparg in "" "-cr 14x14+23+23" "-cr 21x21+4+4" "-cr 18x18+13+13" \
|
|
"-cr 21x21+0+0" "-cr 24x26+20+18"; do
|
|
for xformarg in "" "-f h" "-f v" "-ro 90" "-ro 180" "-ro 270" "-t" \
|
|
"-transv"; do
|
|
for grayarg in "" "-g"; do
|
|
if [ "$grayarg" = "" ]; then
|
|
if [[ "$subsamp" = "410" && "$croparg" != "" ]]; then
|
|
continue
|
|
fi
|
|
else
|
|
if [ "$subsamp" = "gray" ]; then
|
|
continue
|
|
fi
|
|
fi
|
|
for optarg in "" "-o"; do
|
|
if [ "$optarg" = "-o" ]; then
|
|
if [[ "$ariarg" = "-a" || $precision -eq 12 ]]; then
|
|
continue
|
|
fi
|
|
fi
|
|
for progarg in "" "-p"; do
|
|
if [[ "$progarg" = "-p" && "$optarg" = "-o" ]]; then
|
|
continue
|
|
fi
|
|
for restartarg in "" "-r 1 -icc $IMGDIR/test3.icc" \
|
|
"-r 1b"; do
|
|
if [[ "$restartarg" = "-r 1b" && "$croparg" != "" ]]; then
|
|
continue
|
|
fi
|
|
for trimarg in "" "-tri"; do
|
|
if [ "$trimarg" = "-tri" ]; then
|
|
if [[ "$xformarg" = "-t" || "$xformarg" = "" ]]; then
|
|
continue
|
|
fi
|
|
if [ "$croparg" != "" ]; then
|
|
continue
|
|
fi
|
|
fi
|
|
runme $TJTRAN $ariarg $copyarg $croparg $xformarg \
|
|
$grayarg $optarg $progarg $restartarg $trimarg \
|
|
$OUTDIR/${basename}-$subsamp.jpg \
|
|
$OUTDIR/${basename}-tjtran.jpg
|
|
runme $EXEDIR/jpegtran $ariarg $copyarg $croparg \
|
|
$xformarg $grayarg $optarg $progarg $restartarg \
|
|
$trimarg -outf $OUTDIR/${basename}-jpegtran.jpg \
|
|
$OUTDIR/${basename}-$subsamp.jpg
|
|
$EXEDIR/test/md5sum $OUTDIR/${basename}-tjtran.jpg \
|
|
$OUTDIR/${basename}-jpegtran.jpg |
|
|
sed "s@$OUTDIR@\$OUTDIR@g"
|
|
cmp $OUTDIR/${basename}-tjtran.jpg \
|
|
$OUTDIR/${basename}-jpegtran.jpg
|
|
rm $OUTDIR/${basename}-tjtran.jpg \
|
|
$OUTDIR/${basename}-jpegtran.jpg
|
|
echo
|
|
done
|
|
done
|
|
done
|
|
done
|
|
done
|
|
done
|
|
done
|
|
done
|
|
done
|
|
rm $OUTDIR/${basename}-$subsamp.jpg
|
|
done
|
|
done
|
|
|
|
echo "GREAT SUCCESS!"
|