unpack-trees: heed requests to overwrite ignored files
When a directory exists but has only ignored files within it and we are trying to switch to a branch that has a file where that directory is, the behavior depends upon --[no]-overwrite-ignore. If the user wants to --overwrite-ignore (the default), then we should delete the ignored file and directory and switch to the new branch. The code to handle this in verify_clean_subdirectory() in unpack-trees tried to handle this via paying attention to the exclude_per_dir setting of the internal dir field. This came from commitc81935348b("Fix switching to a branch with D/F when current branch has file D.", 2007-03-15), which pre-dated039bc64e88("core.excludesfile clean-up", 2007-11-14), and thus did not pay attention to ignore patterns from other relevant files. Change it to use setup_standard_excludes() so that it is also aware of excludes specified in other locations. Signed-off-by: Elijah Newren <newren@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
committed by
Junio C Hamano
parent
24a49cf78e
commit
b413a82712
@@ -2337,7 +2337,7 @@ static int verify_clean_subdirectory(const struct cache_entry *ce,
|
||||
|
||||
memset(&d, 0, sizeof(d));
|
||||
if (o->dir)
|
||||
d.exclude_per_dir = o->dir->exclude_per_dir;
|
||||
setup_standard_excludes(&d);
|
||||
i = read_directory(&d, o->src_index, pathbuf, namelen+1, NULL);
|
||||
dir_clear(&d);
|
||||
free(pathbuf);
|
||||
|
||||
Reference in New Issue
Block a user