#/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=/mnt/public/Repos/ladybird/Build/vcpkg/buildtrees/libjpeg-turbo/src/3.1.1-23af682a76.clean/testimages
OUTDIR=`mktemp -d /tmp/__tjtrantest_output.XXXXXX`
EXEDIR=/mnt/mint/home/seanl/mnt/public/Repos/ladybird/Build/vcpkg/buildtrees/libjpeg-turbo/x64-linux-dynamic-rel
JAVA=""
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!"
