Commit 20f8a6db by Edward Thomson

apply: remove deleted paths from index

We update the index with the new_file side of the delta, but we need to
explicitly remove the old_file path in the case where an item was
deleted or renamed.
parent 9d81defa
...@@ -558,11 +558,22 @@ int git_apply( ...@@ -558,11 +558,22 @@ int git_apply(
if ((error = apply_one(repo, pre_reader, contents, diff, i)) < 0) if ((error = apply_one(repo, pre_reader, contents, diff, i)) < 0)
goto done; goto done;
/*
* If we're checking out, then we need to keep track of all
* affected paths (removes and adds) so that we can give them
* to checkout to let it handle things. If we're only modifying
* the index, we only care about _removed_ paths: we'll simply
* overwrite the new paths.
*/
if (do_checkout) { if (do_checkout) {
git_vector_insert(&paths, (void *)delta->old_file.path); git_vector_insert(&paths, (void *)delta->old_file.path);
if (strcmp(delta->old_file.path, delta->new_file.path)) if (strcmp(delta->old_file.path, delta->new_file.path))
git_vector_insert(&paths, (void *)delta->new_file.path); git_vector_insert(&paths, (void *)delta->new_file.path);
} else {
if (delta->status == GIT_DELTA_DELETED ||
delta->status == GIT_DELTA_RENAMED)
git_vector_insert(&paths, (void *)delta->old_file.path);
} }
} }
...@@ -579,7 +590,15 @@ int git_apply( ...@@ -579,7 +590,15 @@ int git_apply(
error = git_checkout_index(repo, contents, &checkout_opts); error = git_checkout_index(repo, contents, &checkout_opts);
} else { } else {
const git_index_entry *entry; const git_index_entry *entry;
const char *path;
/* Remove all the deleted paths from the index. */
git_vector_foreach(&paths, i, path) {
if ((error = git_index_remove(repo_index, path, 0)) < 0)
goto done;
}
/* Then add the changes back to the index. */
for (i = 0; i < git_index_entrycount(contents); i++) { for (i = 0; i < git_index_entrycount(contents); i++) {
entry = git_index_get_byindex(contents, i); entry = git_index_get_byindex(contents, i);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment