about summary refs log tree commit diff
path: root/third_party/git/t/lib-pack.sh
diff options
context:
space:
mode:
Diffstat (limited to 'third_party/git/t/lib-pack.sh')
-rw-r--r--third_party/git/t/lib-pack.sh110
1 files changed, 0 insertions, 110 deletions
diff --git a/third_party/git/t/lib-pack.sh b/third_party/git/t/lib-pack.sh
deleted file mode 100644
index c4d907a450..0000000000
--- a/third_party/git/t/lib-pack.sh
+++ /dev/null
@@ -1,110 +0,0 @@
-# Support routines for hand-crafting weird or malicious packs.
-#
-# You can make a complete pack like:
-#
-#   pack_header 2 >foo.pack &&
-#   pack_obj e69de29bb2d1d6434b8b29ae775ad8c2e48c5391 >>foo.pack &&
-#   pack_obj e68fe8129b546b101aee9510c5328e7f21ca1d18 >>foo.pack &&
-#   pack_trailer foo.pack
-
-# Print the big-endian 4-byte octal representation of $1
-uint32_octal () {
-	n=$1
-	printf '\\%o' $(($n / 16777216)); n=$((n % 16777216))
-	printf '\\%o' $(($n /    65536)); n=$((n %    65536))
-	printf '\\%o' $(($n /      256)); n=$((n %      256))
-	printf '\\%o' $(($n           ));
-}
-
-# Print the big-endian 4-byte binary representation of $1
-uint32_binary () {
-	printf "$(uint32_octal "$1")"
-}
-
-# Print a pack header, version 2, for a pack with $1 objects
-pack_header () {
-	printf 'PACK' &&
-	printf '\0\0\0\2' &&
-	uint32_binary "$1"
-}
-
-# Print the pack data for object $1, as a delta against object $2 (or as a full
-# object if $2 is missing or empty). The output is suitable for including
-# directly in the packfile, and represents the entirety of the object entry.
-# Doing this on the fly (especially picking your deltas) is quite tricky, so we
-# have hardcoded some well-known objects. See the case statements below for the
-# complete list.
-pack_obj () {
-	case "$1" in
-	# empty blob
-	e69de29bb2d1d6434b8b29ae775ad8c2e48c5391)
-		case "$2" in
-		'')
-			printf '\060\170\234\003\0\0\0\0\1'
-			return
-			;;
-		esac
-		;;
-
-	# blob containing "\7\76"
-	e68fe8129b546b101aee9510c5328e7f21ca1d18)
-		case "$2" in
-		'')
-			printf '\062\170\234\143\267\3\0\0\116\0\106'
-			return
-			;;
-		01d7713666f4de822776c7622c10f1b07de280dc)
-			printf '\165\1\327\161\66\146\364\336\202\47\166' &&
-			printf '\307\142\54\20\361\260\175\342\200\334\170' &&
-			printf '\234\143\142\142\142\267\003\0\0\151\0\114'
-			return
-			;;
-		esac
-		;;
-
-	# blob containing "\7\0"
-	01d7713666f4de822776c7622c10f1b07de280dc)
-		case "$2" in
-		'')
-			printf '\062\170\234\143\147\0\0\0\20\0\10'
-			return
-			;;
-		e68fe8129b546b101aee9510c5328e7f21ca1d18)
-			printf '\165\346\217\350\22\233\124\153\20\32\356' &&
-			printf '\225\20\305\62\216\177\41\312\35\30\170\234' &&
-			printf '\143\142\142\142\147\0\0\0\53\0\16'
-			return
-			;;
-		esac
-		;;
-	esac
-
-	# If it's not a delta, we can convince pack-objects to generate a pack
-	# with just our entry, and then strip off the header (12 bytes) and
-	# trailer (20 bytes).
-	if test -z "$2"
-	then
-		echo "$1" | git pack-objects --stdout >pack_obj.tmp &&
-		size=$(wc -c <pack_obj.tmp) &&
-		dd if=pack_obj.tmp bs=1 count=$((size - 20 - 12)) skip=12 &&
-		rm -f pack_obj.tmp
-		return
-	fi
-
-	echo >&2 "BUG: don't know how to print $1${2:+ (from $2)}"
-	return 1
-}
-
-# Compute and append pack trailer to "$1"
-pack_trailer () {
-	test-tool sha1 -b <"$1" >trailer.tmp &&
-	cat trailer.tmp >>"$1" &&
-	rm -f trailer.tmp
-}
-
-# Remove any existing packs to make sure that
-# whatever we index next will be the pack that we
-# actually use.
-clear_packs () {
-	rm -f .git/objects/pack/*
-}