Skip to content

Commit

Permalink
[PATCH] When copying or renaming, keep the mode, please
Browse files Browse the repository at this point in the history
Without this patch, git-apply does not retain the mode when renaming or
copying files.

[jc: Good catch, Johannes.  I added a test case to demonstrate the
breackage in the original.]

Signed-off-by: Johannes Schindelin <[email protected]>
Signed-off-by: Junio C Hamano <[email protected]>
  • Loading branch information
dscho authored and Junio C Hamano committed Aug 17, 2005
1 parent e4aec26 commit 35cc4bc
Show file tree
Hide file tree
Showing 2 changed files with 43 additions and 2 deletions.
8 changes: 6 additions & 2 deletions apply.c
Original file line number Diff line number Diff line change
Expand Up @@ -1043,8 +1043,12 @@ static int check_patch(struct patch *patch)
return error("%s: already exists in working directory", new_name);
if (errno != ENOENT)
return error("%s: %s", new_name, strerror(errno));
if (!patch->new_mode)
patch->new_mode = S_IFREG | 0644;
if (!patch->new_mode) {
if (patch->is_new)
patch->new_mode = S_IFREG | 0644;
else
patch->new_mode = patch->old_mode;
}
}

if (new_name && old_name) {
Expand Down
37 changes: 37 additions & 0 deletions t/t4102-apply-rename.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
#!/bin/sh
#
# Copyright (c) 2005 Junio C Hamano
#

test_description='git-apply handling copy/rename patch.
'
. ./test-lib.sh

# setup

cat >test-patch <<\EOF
diff --git a/foo b/bar
similarity index 47%
copy from foo
copy to bar
--- a/foo
+++ b/bar
@@ -1 +1 @@
-This is foo
+This is bar
EOF

echo 'This is foo' >foo
chmod +x foo

test_expect_success setup \
'git-update-cache --add foo'

test_expect_success apply \
'git-apply --index --stat --summary --apply test-patch'

test_expect_success validate \
'test -f bar && ls -l bar | grep "^-..x..x..x"'

test_done

0 comments on commit 35cc4bc

Please sign in to comment.