summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--builtin/mv.c3
-rwxr-xr-xt/t6039-merge-ignorecase.sh2
2 files changed, 3 insertions, 2 deletions
diff --git a/builtin/mv.c b/builtin/mv.c
index 45e57f307b..f4d89d0640 100644
--- a/builtin/mv.c
+++ b/builtin/mv.c
@@ -202,7 +202,8 @@ int cmd_mv(int argc, const char **argv, const char *prefix)
}
} else if (cache_name_pos(src, length) < 0)
bad = _("not under version control");
- else if (lstat(dst, &st) == 0) {
+ else if (lstat(dst, &st) == 0 &&
+ (!ignore_case || strcasecmp(src, dst))) {
bad = _("destination exists");
if (force) {
/*
diff --git a/t/t6039-merge-ignorecase.sh b/t/t6039-merge-ignorecase.sh
index dfc9f17a2d..a977653147 100755
--- a/t/t6039-merge-ignorecase.sh
+++ b/t/t6039-merge-ignorecase.sh
@@ -35,7 +35,7 @@ test_expect_success 'merge with case-changing rename on both sides' '
git reset --hard baseline &&
git branch -D with-camel &&
git checkout -b with-camel &&
- git mv --force TestCase testcase &&
+ git mv TestCase testcase &&
git commit -m "recase on branch" &&
>foo &&
git add foo &&