summaryrefslogtreecommitdiff
path: root/git-repack-script
diff options
context:
space:
mode:
authorJunio C Hamano <junkio@cox.net>2005-08-24 17:40:58 (GMT)
committerJunio C Hamano <junkio@cox.net>2005-08-24 17:40:58 (GMT)
commitccf1ee327f9a7d51704578fa41ba255abfd3a730 (patch)
treed4413df35e7946d47678dbd061efbb89196a0e4c /git-repack-script
parent0d6a873cfe4ba9428cf361c633faf701cadc04b8 (diff)
downloadgit-ccf1ee327f9a7d51704578fa41ba255abfd3a730.zip
git-ccf1ee327f9a7d51704578fa41ba255abfd3a730.tar.gz
git-ccf1ee327f9a7d51704578fa41ba255abfd3a730.tar.bz2
Generate pack info file after repack.
Pulling from a packed repository over dumb transport without the server info file fails, so run update-server-info automatically after a repack by default. This can be disabled with the '-n' flag. Signed-off-by: Junio C Hamano <junkio@cox.net>
Diffstat (limited to 'git-repack-script')
-rwxr-xr-xgit-repack-script21
1 files changed, 20 insertions, 1 deletions
diff --git a/git-repack-script b/git-repack-script
index 15b7fd6..1c9a631 100755
--- a/git-repack-script
+++ b/git-repack-script
@@ -1,6 +1,20 @@
#!/bin/sh
+#
+# Copyright (c) 2005 Linus Torvalds
+#
+
. git-sh-setup-script || die "Not a git archive"
+no_update_info=
+while case "$#" in 0) break ;; esac
+do
+ case "$1" in
+ -n) no_update_info=t ;;
+ *) break ;;
+ esac
+ shift
+done
+
rm -f .tmp-pack-*
packname=$(git-rev-list --unpacked --objects $(git-rev-parse --all) |
git-pack-objects --non-empty --incremental .tmp-pack) ||
@@ -9,6 +23,11 @@ if [ -z "$packname" ]; then
echo Nothing new to pack
exit 0
fi
+
mkdir -p "$GIT_OBJECT_DIRECTORY/pack" &&
mv .tmp-pack-$packname.pack "$GIT_OBJECT_DIRECTORY/pack/pack-$packname.pack" &&
-mv .tmp-pack-$packname.idx "$GIT_OBJECT_DIRECTORY/pack/pack-$packname.idx"
+mv .tmp-pack-$packname.idx "$GIT_OBJECT_DIRECTORY/pack/pack-$packname.idx" &&
+case "$no_update_info" in
+t) : ;;
+*) git-update-server-info ;;
+esac