summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLibravatar Junio C Hamano <junkio@cox.net>2006-05-19 16:59:29 -0700
committerLibravatar Junio C Hamano <junkio@cox.net>2006-05-19 16:59:29 -0700
commitedd5cc242820f3eec26329a263e4016a039adee1 (patch)
treee1b056b9e87491920904d9f134a3f5579a15a900
parentMerge branch 'eb/quilt' (diff)
parentapply --cached: do not check newly added file in the working tree (diff)
downloadtgif-edd5cc242820f3eec26329a263e4016a039adee1.tar.xz
Merge branch 'jc/apply'
* jc/apply: apply --cached: do not check newly added file in the working tree
-rw-r--r--apply.c10
1 files changed, 6 insertions, 4 deletions
diff --git a/apply.c b/apply.c
index b3b9b40596..0ed9d132e8 100644
--- a/apply.c
+++ b/apply.c
@@ -1711,10 +1711,12 @@ static int check_patch(struct patch *patch)
if (new_name && (patch->is_new | patch->is_rename | patch->is_copy)) {
if (check_index && cache_name_pos(new_name, strlen(new_name)) >= 0)
return error("%s: already exists in index", new_name);
- if (!cached && !lstat(new_name, &st))
- return error("%s: already exists in working directory", new_name);
- if (errno != ENOENT)
- return error("%s: %s", new_name, strerror(errno));
+ if (!cached) {
+ if (!lstat(new_name, &st))
+ 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) {
if (patch->is_new)
patch->new_mode = S_IFREG | 0644;