aboutsummaryrefslogtreecommitdiff
path: root/git-prune-script
diff options
context:
space:
mode:
authorJunio C Hamano <junkio@cox.net>2005-05-04 01:33:33 -0700
committerJunio C Hamano <junkio@cox.net>2005-05-04 01:33:33 -0700
commitae7c0c92c0713307986bcd1fb54fa0694aae962a (patch)
tree74bcaa311990e35754b33479bf0bca7b5bfae16d /git-prune-script
parentfd0ffd3ad12d6aa49b8ac2cce7728976d678cc63 (diff)
downloadgit-ae7c0c92c0713307986bcd1fb54fa0694aae962a.tar.gz
git-ae7c0c92c0713307986bcd1fb54fa0694aae962a.tar.xz
Git-prune-script loses blobs referenced from an uncommitted cache.
(updated from the version posted to GIT mailing list). When a new blob is registered with update-cache, and before the cache is written as a tree and committed, git-fsck-cache will find the blob unreachable. This patch adds a new flag, "--cache" to git-fsck-cache, with which it keeps such blobs from considered "unreachable". The git-prune-script is updated to use this new flag. At the same time it adds .git/refs/*/* to the set of default locations to look for heads, which should be consistent with expectations from Cogito users. Without this fix, "diff-cache -p --cached" after git-prune-script has pruned the blob object will fail mysteriously and git-write-tree would also fail. Signed-off-by: Junio C Hamano <junkio@cox.net>
Diffstat (limited to 'git-prune-script')
-rwxr-xr-xgit-prune-script37
1 files changed, 36 insertions, 1 deletions
diff --git a/git-prune-script b/git-prune-script
index b6e927a74..30a989e8f 100755
--- a/git-prune-script
+++ b/git-prune-script
@@ -1,2 +1,37 @@
#!/bin/sh
-git-fsck-cache --unreachable $(cat .git/HEAD ) | grep unreachable | cut -d' ' -f3 | sed 's:^\(..\):.git/objects/\1/:' | xargs rm
+
+dryrun=
+while case "$#" in 0) break ;; esac
+do
+ case "$1" in
+ -n) dryrun=echo ;;
+ --) break ;;
+ -*) echo >&2 "usage: git-prune-script [ -n ] [ heads... ]"; exit 1 ;;
+ *) break ;;
+ esac
+ shift;
+done
+
+# Defaulting to include .git/refs/*/* may be debatable from the
+# purist POV but power users can always give explicit parameters
+# to the script anyway.
+
+case "$#" in
+0)
+ x_40='[0-9a-f][0-9a-f][0-9a-f][0-9a-f][0-9a-f]'
+ x_40="$x_40$x_40$x_40$x_40$x_40$x_40$x_40$x_40"
+ set x $(sed -ne "/^$x_40\$/p" .git/HEAD .git/refs/*/* 2>/dev/null)
+ shift ;;
+esac
+
+git-fsck-cache --cache --unreachable "$@" |
+sed -ne '/unreachable /{
+ s/unreachable [^ ][^ ]* //
+ s|\(..\)|\1/|p
+}' | {
+ case "$SHA1_FILE_DIRECTORY" in
+ '') cd .git/objects/ ;;
+ *) cd "$SHA1_FILE_DIRECTORY" ;;
+ esac || exit
+ xargs -r $dryrun rm -f
+}