Merge branch 'fix'

* fix:
  Make git-reset delete empty directories
This commit is contained in:
Junio C Hamano
2006-02-18 01:26:14 -08:00
2 changed files with 66 additions and 0 deletions

View File

@@ -88,6 +88,9 @@ case "$reset_type" in
# it is ok if this fails -- it may already
# have been culled by checkout-index.
unlink $_;
while (s|/[^/]*$||) {
rmdir($_) or last;
}
}
}
' $tmp-exists

63
t/t7101-reset.sh Executable file
View File

@@ -0,0 +1,63 @@
#!/bin/sh
#
# Copyright (c) 2006 Shawn Pearce
#
test_description='git-reset should cull empty subdirs'
. ./test-lib.sh
test_expect_success \
'creating initial files' \
'mkdir path0 &&
cp ../../COPYING path0/COPYING &&
git-add path0/COPYING &&
git-commit -m add -a'
test_expect_success \
'creating second files' \
'mkdir path1 &&
mkdir path1/path2 &&
cp ../../COPYING path1/path2/COPYING &&
cp ../../COPYING path1/COPYING &&
cp ../../COPYING COPYING &&
cp ../../COPYING path0/COPYING-TOO &&
git-add path1/path2/COPYING &&
git-add path1/COPYING &&
git-add COPYING &&
git-add path0/COPYING-TOO &&
git-commit -m change -a'
test_expect_success \
'resetting tree HEAD^' \
'git-reset --hard HEAD^'
test_expect_success \
'checking initial files exist after rewind' \
'test -d path0 &&
test -f path0/COPYING'
test_expect_failure \
'checking lack of path1/path2/COPYING' \
'test -f path1/path2/COPYING'
test_expect_failure \
'checking lack of path1/COPYING' \
'test -f path1/COPYING'
test_expect_failure \
'checking lack of COPYING' \
'test -f COPYING'
test_expect_failure \
'checking checking lack of path1/COPYING-TOO' \
'test -f path0/COPYING-TOO'
test_expect_failure \
'checking lack of path1/path2' \
'test -d path1/path2'
test_expect_failure \
'checking lack of path1' \
'test -d path1'
test_done