Blob Blame History Raw
#!/bin/sh

error () {
	echo >&2 "error: $@"
	exit 1
}

find_embedded_trash () {
	while read -r line
	do
		case "$line" in
		*Start\ of\ trash\ directory\ of\ \'t[0-9][0-9][0-9][0-9]-*\':*)
			test_name="${line#*\'}"
			test_name="${test_name%\'*}"

			return 0
		esac
	done

	return 1
}

extract_embedded_trash () {
	while read -r line
	do
		case "$line" in
		*End\ of\ trash\ directory\ of\ \'$test_name\'*)
			return
			;;
		*)
			printf '%s\n' "$line"
			;;
		esac
	done

	error "unexpected end of input"
}

# Raw logs from Linux build jobs have CRLF line endings, while OSX
# build jobs mostly have CRCRLF, except an odd line every now and
# then that has CRCRCRLF.  'base64 -d' from 'coreutils' doesn't like
# CRs and complains about "invalid input", so remove all CRs at the
# end of lines.
sed -e 's/\r*$//' | \
while find_embedded_trash
do
	echo "Extracting trash directory of '$test_name'"

	extract_embedded_trash |base64 -d |tar xzp
done