summaryrefslogtreecommitdiff
path: root/t/t4006-diff-mode.sh
diff options
context:
space:
mode:
authorLibravatar Junio C Hamano <gitster@pobox.com>2012-03-15 01:04:12 -0700
committerLibravatar Junio C Hamano <gitster@pobox.com>2012-03-15 11:25:34 -0700
commitae2f203ef7be7b33ff5ec61646c8662363eccd62 (patch)
treefc2d3717e6762b96a6b0d2c4adf6aad5e38a9cb6 /t/t4006-diff-mode.sh
parentremove_dir_recursively(): Add flag for skipping removal of toplevel dir (diff)
downloadtgif-ae2f203ef7be7b33ff5ec61646c8662363eccd62.tar.xz
clean: preserve nested git worktree in subdirectories
remove_dir_recursively() has a check to avoid removing the directory it was asked to remove without recursing into it and report success when the directory is the top level of a working tree of a nested git repository, to protect such a repository from "clean -f" (without double -f). If a working tree of a nested git repository is in a subdirectory of a toplevel project, however, this protection did not apply by mistake; we forgot to pass the REMOVE_DIR_KEEP_NESTED_GIT down to the recursive removal codepath. This requires us to also teach the higher level not to remove the directory it is asked to remove, when the recursed invocation did not remove the directory it was asked to remove due to a nested git repository, as it is not an error to leave the parent directories of such a nested repository. Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 't/t4006-diff-mode.sh')
0 files changed, 0 insertions, 0 deletions