]> git.ipfire.org Git - thirdparty/git.git/commitdiff
Allow git-filter-branch to process large repositories with lots of branches.
authorLee Carver <Lee.Carver@servicenow.com>
Tue, 10 Sep 2013 22:55:35 +0000 (22:55 +0000)
committerJunio C Hamano <gitster@pobox.com>
Thu, 12 Sep 2013 18:00:51 +0000 (11:00 -0700)
A recommended way to move trees between repositories is to use
git-filter-branch to revise the history for a single tree:

However, this can lead to "argument list too long" errors when the
original repository has many retained branches (>6k)

    /usr/local/git/libexec/git-core/git-filter-branch: line 270:
    /usr/local/git/libexec/git-core/git: Argument list too long
    Could not get the commits

Saving the output from rev-parse and feeding it into rev-list from
its standard input avoids this problem, since the rev-parse output
is not processed as a command line argument.

Signed-off-by: Lee Carver <Lee.Carver@servicenow.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
git-filter-branch.sh

index ac2a005fdb23c48d8451188ffd7b1c8194b0295f..ca3d53919ad3b9b07a7147c31b7719c6ccca6232 100755 (executable)
@@ -255,7 +255,7 @@ else
        remap_to_ancestor=t
 fi
 
-rev_args=$(git rev-parse --revs-only "$@")
+git rev-parse --revs-only "$@" >../parse
 
 case "$filter_subdir" in
 "")
@@ -268,7 +268,7 @@ case "$filter_subdir" in
 esac
 
 git rev-list --reverse --topo-order --default HEAD \
-       --parents --simplify-merges $rev_args "$@" > ../revs ||
+       --parents --simplify-merges --stdin "$@" <../parse >../revs ||
        die "Could not get the commits"
 commits=$(wc -l <../revs | tr -d " ")