我在git存储库中重命名了一个文件:
git mv oldname.py newname.py
然后git status
告诉我需要提交的更改是重命名文件。我没有写git add newname.py
。
我提交并推送到GitHub,然后文件的名称已成功更改。
但是当我在GitHub上看到该文件的历史记录时,它只包含最后一次提交,而不是所有提交。
有人可以向我解释发生了什么吗?
答案 0 :(得分:0)
git mv a b
会自动将重命名的文件b
添加到暂存区域。这实际上和做
mv a b
git rm a
git add b
或
cp a b
git rm a
git add b
在这种情况下,可以清楚地看到为什么某些客户端(如GitHub的Web界面)会将这两个文件视为单独的。
答案 1 :(得分:0)
移动时,Git不会移动文件中的编辑历史记录。在进行修补,还原提交等时会产生大量问题。git mv
是删除文件和添加到跟踪文件列表的快捷方式。
GitHub没有显示文件的完整历史记录,但您可以使用git log --follow newname.py
手动完成,它应该在git mv
之前显示更改