This uses the new "--local" flag to git-pack-objects. It currently only makes a difference together with "-a", since a normal incremental repack won't pack any packed objects at all (whether local or remote). Eventually, it might end up skipping any objects that aren't local to the current object directory, but for now it only knows to skip packed objects. Signed-off-by: Linus Torvalds <torvalds@osdl.org> --- Ok, that was the last of it. I tested it out by doing a git clone -l -s git newgit cd newgit .. do a dummy commit .. git repack -a -d -l and then cd ../git git repack -a -d cd ../newgit git repack -a -d -l and verified that the repacks in "newgit" all seemed to do the right thing (ie they only repacked objects that weren't packed in the original git, and repacking the original git archive caused the repack in the new one to shrink considerably). This means that my suggested automatic repacking should work fine with alternate object directories too, except my second script (the periodic full repack) would needs to be updated to use the new "-l" flag. diff --git a/git-repack.sh b/git-repack.sh index b395d0e..49547a7 100755 --- a/git-repack.sh +++ b/git-repack.sh @@ -5,13 +5,14 @@ . git-sh-setup || die "Not a git archive" -no_update_info= all_into_one= remove_redundant= +no_update_info= all_into_one= remove_redundant= local= while case "$#" in 0) break ;; esac do case "$1" in -n) no_update_info=t ;; -a) all_into_one=t ;; -d) remove_redandant=t ;; + -l) local=t ;; *) break ;; esac shift @@ -37,6 +38,9 @@ case ",$all_into_one," in find . -type f \( -name '*.pack' -o -name '*.idx' \) -print` ;; esac +if [ "$local" ]; then + pack_objects="$pack_objects --local" +fi name=$(git-rev-list --objects $rev_list $(git-rev-parse $rev_parse) | git-pack-objects --non-empty $pack_objects .tmp-pack) || exit 1 - To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.htmlReceived on Fri Oct 14 07:30:37 2005
This archive was generated by hypermail 2.1.8 : 2005-10-14 07:30:41 EST