Skip to content

Commit

Permalink
builtin-rm: fix index lock file path
Browse files Browse the repository at this point in the history
When hold_locked_index() is called with a relative git_dir and you are
outside the work tree, the lock file become relative to the current
directory. So when later setup_work_tree() change the current directory
it breaks lock file path and commit_locked_index() fails.

This patch move index locking code after setup_work_tree() call to make
lock file relative to the working tree as it should be and add a test
case.

Noticed by Nick Andrew.

Signed-off-by: Olivier Marin <dkr@freesurf.fr>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
  • Loading branch information
Olivier Marin authored and gitster committed Jul 19, 2008
1 parent fcf74db commit 4d26467
Show file tree
Hide file tree
Showing 2 changed files with 17 additions and 5 deletions.
10 changes: 5 additions & 5 deletions builtin-rm.c
Original file line number Diff line number Diff line change
Expand Up @@ -146,18 +146,18 @@ int cmd_rm(int argc, const char **argv, const char *prefix)

git_config(git_default_config, NULL);

newfd = hold_locked_index(&lock_file, 1);

if (read_cache() < 0)
die("index file corrupt");

argc = parse_options(argc, argv, builtin_rm_options, builtin_rm_usage, 0);
if (!argc)
usage_with_options(builtin_rm_usage, builtin_rm_options);

if (!index_only)
setup_work_tree();

newfd = hold_locked_index(&lock_file, 1);

if (read_cache() < 0)
die("index file corrupt");

pathspec = get_pathspec(prefix, argv);
seen = NULL;
for (i = 0; pathspec[i] ; i++)
Expand Down
12 changes: 12 additions & 0 deletions t/t3600-rm.sh
Original file line number Diff line number Diff line change
Expand Up @@ -217,4 +217,16 @@ test_expect_success 'Remove nonexistent file returns nonzero exit status' '
! git rm nonexistent
'

test_expect_success 'Call "rm" from outside the work tree' '
mkdir repo &&
cd repo &&
git init &&
echo something > somefile &&
git add somefile &&
git commit -m "add a file" &&
(cd .. &&
git --git-dir=repo/.git --work-tree=repo rm somefile) &&
test_must_fail git ls-files --error-unmatch somefile
'

test_done

0 comments on commit 4d26467

Please sign in to comment.