虽然我发现了类似的问题,但我没有找到问题的答案

当我尝试重命名目录从FOO到FOO通过git mv FOO FOO我得到

fatal: renaming 'FOO' failed: Invalid argument

好的。我试试gitmv FOO foo2 && gitmv foo2 FOO

但当我尝试通过git commit提交时。我得到

# On branch master
# Untracked files:
#   (use "git add <file>..." to include in what will be committed)
#
# foo
nothing added to commit but untracked files present (use "git add" to track)

当我通过git添加目录时,添加foo没有任何变化,git提交。又给了我同样的信息。

我做错了什么?我认为我正在使用区分大小写的系统(OSX),为什么我不能简单地重命名目录?


当前回答

这里有一个关于这个页面上所有gitfoo的非常简单的解决方案。

手动从项目中复制文件。 Git rm所有文件。 Git像正常一样提交。 手动重新添加文件。 Git添加所有文件。 Git像正常一样提交。 利润。

其他回答

(无 git mv 变体。

我在Mac OS X 10.9上的Git中遇到了这个问题。我是这样解决的:

Git rm -r——缓存/路径/到/目录

这将在Git中逐步删除目录,但并不实际删除任何物理文件(——cached)。这也使得目录(现在有了正确的大小写)显示在未跟踪的文件中。

所以你可以这样做:

mv /path/to/directory /path/to/DIRECTORY
git add -A /path/to/DIRECTORY

Git会识别你重命名了文件,当你执行Git status时,你会看到一些重命名的:行。检查它们并确保它们看起来正确,如果是这样,您就可以正常提交更改。

我能够解决这个问题,使用git 1.7.7通过使用临时文件名:

$ git mv improper_Case improve_case2
$ git mv improve_case2 improve_case
$ git commit -m "<your message>"

这是一个快速且安全的解决方案:

git mv -f path/to/foo/* path/to/FOO/

警告!始终重命名重命名文件夹中的所有文件(使用/*)。

不要重命名单个文件。这将导致一个错误,在这个答案中描述。

如果你想先看到结果,使用-n:

git mv -f -n path/to/foo/* path/to/FOO/

在你完成mv之后:

提交修改 签出到任何其他修订 结帐。

现在Git应该在内部文件和文件系统中都重命名了文件夹。

您所处的环境不区分大小写。此外,不带-A的添加不会像Git理解的那样处理mv的删除部分。警告!确保在执行此操作时没有其他更改或未跟踪的文件,否则它们将作为此更改的一部分提交!先做Git stash -u,然后再做Git stash pop。继续:要解决这个问题,请执行以下步骤:

mv foo foo2
git add -A
git commit -m "renaming"
mv foo2 FOO
git add -A
git commit --amend -m "renamed foo to FOO"

这是改变工作目录的拉长方式,提交然后折叠两次提交。您可以在索引中移动文件,但是对于git的新手来说,它可能不够明确地说明发生了什么。简短的版本是

git mv foo foo2
git mv foo2 FOO
git commit -m "changed case of dir"

正如其中一条评论所建议的那样,您还可以执行交互式rebase (git rebase -i HEAD~5,如果在5次提交之前引入了错误的case)来修复那里的case,并且在历史记录中根本不会出现错误的case。如果你这样做,你必须小心,因为从那时起提交哈希将是不同的,其他人将不得不重新建立或重新合并他们的工作与最近的过去的分支。

这与纠正文件名有关:git不区分大小写吗?

改进Adam Dymitruk的答案(SO不让我评论他的答案很愚蠢),使用“git mv”将自动准确地呈现移动的文件。不需要存储,并且可以避免有风险的“git add -A”:

old="abc";    new="ABC";
tmp="$old-renamed";
git mv "$old" "$tmp";
git commit -m "Renamed '$old' to '$tmp'.";
git mv "$tmp" "$new";
git commit --amend -m "Renamed '$old' to '$new'.";