mv: allow renaming to fix case on case insensitive filesystems
authorDavid Turner <dturner@twitter.com>
Thu, 8 May 2014 17:23:34 +0000 (10:23 -0700)
committerJunio C Hamano <gitster@pobox.com>
Thu, 8 May 2014 21:34:00 +0000 (14:34 -0700)
"git mv hello.txt Hello.txt" on a case insensitive filesystem
always triggers "destination already exists" error, because these
two names refer to the same path from the filesystem's point of
view, and requires the user to give "--force" when correcting the
case of the path recorded in the index and in the next commit.

Detect this case and allow it without requiring "--force".

Signed-off-by: David Turner <dturner@twitter.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
builtin/mv.c
t/t6039-merge-ignorecase.sh
index 45e57f307b799490a949d60b37f8cff1a1e5d07f..f4d89d06408be1fabf964000b18fa8204a9bb3a4 100644 (file)
@@ -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) {
                                /*
index dfc9f17a2d6f80bbc40bfc65605e7240559df01b..a97765314739be68cdd82e0b6f8dadd12f10a0a4 100755 (executable)
@@ -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 &&