Merge branch 'tg/stash-keep-index-with-removed-paths'

"git stash --keep-index" did not work correctly on paths that have
been removed, which has been fixed.

* tg/stash-keep-index-with-removed-paths:
  stash: fix handling removed files with --keep-index
This commit is contained in:
Junio C Hamano 2019-07-25 13:59:23 -07:00
commit f8aee8576a
2 changed files with 16 additions and 23 deletions

View File

@ -1391,30 +1391,16 @@ static int do_push_stash(const struct pathspec *ps, const char *stash_msg, int q
} }
if (keep_index == 1 && !is_null_oid(&info.i_tree)) { if (keep_index == 1 && !is_null_oid(&info.i_tree)) {
struct child_process cp_ls = CHILD_PROCESS_INIT; struct child_process cp = CHILD_PROCESS_INIT;
struct child_process cp_checkout = CHILD_PROCESS_INIT;
struct strbuf out = STRBUF_INIT;
if (reset_tree(&info.i_tree, 0, 1)) { cp.git_cmd = 1;
ret = -1; argv_array_pushl(&cp.args, "checkout", "--no-overlay",
goto done; oid_to_hex(&info.i_tree), "--", NULL);
} if (!ps->nr)
argv_array_push(&cp.args, ":/");
cp_ls.git_cmd = 1; else
argv_array_pushl(&cp_ls.args, "ls-files", "-z", add_pathspecs(&cp.args, ps);
"--modified", "--", NULL); if (run_command(&cp)) {
add_pathspecs(&cp_ls.args, ps);
if (pipe_command(&cp_ls, NULL, 0, &out, 0, NULL, 0)) {
ret = -1;
goto done;
}
cp_checkout.git_cmd = 1;
argv_array_pushl(&cp_checkout.args, "checkout-index",
"-z", "--force", "--stdin", NULL);
if (pipe_command(&cp_checkout, out.buf, out.len, NULL,
0, NULL, 0)) {
ret = -1; ret = -1;
goto done; goto done;
} }

View File

@ -1234,4 +1234,11 @@ test_expect_success 'stash works when user.name and user.email are not set' '
) )
' '
test_expect_success 'stash --keep-index with file deleted in index does not resurrect it on disk' '
test_commit to-remove to-remove &&
git rm to-remove &&
git stash --keep-index &&
test_path_is_missing to-remove
'
test_done test_done