summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPaul Talacko <gnuruandstuff@yahoo.co.uk>2008-09-06 18:50:38 -0700
committerEric Wong <normalperson@yhbt.net>2008-09-06 18:58:59 -0700
commit7c4d0219cf9ab6a7738a09ad7fec72d5e9f2ac67 (patch)
tree68a6ffc8cb5f695db980ae4ceae34f8e26e25583
parenta786091b4a487bc08bbff4864717cf5d8383e983 (diff)
downloadgit-7c4d0219cf9ab6a7738a09ad7fec72d5e9f2ac67.tar.gz
git-svn: set auto_props when renaming files
Patch-by: Paul Talacko <gnuruandstuff@yahoo.co.uk>: <http://article.gmane.org/gmane.comp.version-control.git/95006> > Hello, > > There's an issue in git-svn as autoprops are not applied to > renamed files, only to added files. > > This patch fixes the bug. [ew: added test case] Signed-off-by: Eric Wong <normalperson@yhbt.net>
-rwxr-xr-xgit-svn.perl1
-rwxr-xr-xt/t9124-git-svn-dcommit-auto-props.sh17
2 files changed, 18 insertions, 0 deletions
diff --git a/git-svn.perl b/git-svn.perl
index 2cc64876b2..ee3f5edb60 100755
--- a/git-svn.perl
+++ b/git-svn.perl
@@ -3657,6 +3657,7 @@ sub R {
my $fbat = $self->add_file($self->repo_path($m->{file_b}), $pbat,
$self->url_path($m->{file_a}), $self->{r});
print "\tR\t$m->{file_a} => $m->{file_b}\n" unless $::_q;
+ $self->apply_autoprops($file, $fbat);
$self->chg_file($fbat, $m);
$self->close_file($fbat,undef,$self->{pool});
diff --git a/t/t9124-git-svn-dcommit-auto-props.sh b/t/t9124-git-svn-dcommit-auto-props.sh
index 54276bf115..31193a382a 100755
--- a/t/t9124-git-svn-dcommit-auto-props.sh
+++ b/t/t9124-git-svn-dcommit-auto-props.sh
@@ -81,4 +81,21 @@ test_expect_success 'check resulting svn repository' '
)
'
+test_expect_success 'check renamed file' '
+ test -d user &&
+ generate_auto_props yes > user/config &&
+ git mv foo foo.sh &&
+ git commit -m "foo => foo.sh" &&
+ git svn dcommit --config-dir=user &&
+ (
+ cd work/svnrepo &&
+ svn up &&
+ test ! -e foo &&
+ test -e foo.sh &&
+ test "x$(svn propget svn:mime-type foo.sh)" = \
+ "xapplication/x-shellscript" &&
+ test "x$(svn propget svn:eol-style foo.sh)" = "xLF"
+ )
+'
+
test_done