[PATCH] filter-branch: Fix renaming a directory in the tree-filter

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



From: Jean-François Veillette <jean francois veillette@xxxxxxxx>

Commit d89c1dfac939623a269f60d4e27e3a2929dca29c replaced a
'ls-files | xargs rm' pipeline by 'git clean'. But since 'git clean' does
not recurse and remove directories by default. Now, consider a tree-filter
that renames a directory.

1. For the first commit everything works as expected
2. Then filter-branch checks out the files for the next commit. This
   leaves the new directory behind because there is no real "branch
   switching" involved that would notice that the directory can be
   removed.
3. Then filter-branch invokes 'git clean' to remove exactly those
   left-overs. But here it does not remove the directory.
4. The next tree-filter does not work as expected because there already
   exists a directory with the new name.

Just add -d to 'git clean'.

Signed-off-by: Johannes Sixt <johannes.sixt@xxxxxxxxxx>
---
 Jean-Francois, there's no sign-off from you. Ok to add it?

 -- Hannes

 git-filter-branch.sh     |    2 +-
 t/t7003-filter-branch.sh |    2 +-
 2 files changed, 2 insertions(+), 2 deletions(-)

diff --git a/git-filter-branch.sh b/git-filter-branch.sh
index 22b6ed4..ea59015 100755
--- a/git-filter-branch.sh
+++ b/git-filter-branch.sh
@@ -281,7 +281,7 @@ while read commit parents; do
 			die "Could not checkout the index"
 		# files that $commit removed are now still in the working tree;
 		# remove them, else they would be added again
-		git clean -q -f -x
+		git clean -d -q -f -x
 		eval "$filter_tree" < /dev/null ||
 			die "tree filter failed: $filter_tree"
 
diff --git a/t/t7003-filter-branch.sh b/t/t7003-filter-branch.sh
index 53b5ce6..efd658a 100755
--- a/t/t7003-filter-branch.sh
+++ b/t/t7003-filter-branch.sh
@@ -53,7 +53,7 @@ test_expect_success 'rewrite, renaming a specific directory' '
 	git-filter-branch -f --tree-filter "mv dir diroh || :" HEAD
 '
 
-test_expect_failure 'test that the directory was renamed' '
+test_expect_success 'test that the directory was renamed' '
 	test dir/d = "$(git show HEAD:diroh/d --)" &&
 	! test -d dir &&
 	test -d diroh &&
-- 
1.5.4.4

--
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]

  Powered by Linux