【发布时间】:2011-05-22 13:36:36
【问题描述】:
我使用git mv 重命名了几个文件,使用了git stash,快速查看了HEAD(不更改它),然后使用git stash pop 重新获得了全部文件。我的动作已经从提交列表中消失了,所以我用git rm 重做了它们,并且提交消息声称 git 发现重命名是重命名。所以我没有更多的考虑。
但是现在,提交后,我无法获得移动文件的历史记录!以下是 git 关于提交的内容:
~/projects% git log --summary
commit de6e9fa2179ae17ec35a5c368d246f19da27f93a
Author: brone
Date: Wed Dec 8 22:37:54 2010 +0000
Moved R_DebugUI into runtime
delete mode 100644 test/R_DebugUI_iOS.h
delete mode 100644 test/R_DebugUI_iOS.m
create mode 100644 system/runtime/src/R_DebugUI_iOS.h
create mode 100644 system/runtime/src/R_DebugUI_iOS.m
<<snip older commits>>
~/projects%
我现在正在尝试获取其中一个移动文件的历史记录,以便查看旧版本,但没有得到任何有用的信息:
~/projects/system/runtime/src% git log --follow --find-copies-harder -M -C R_DebugUI_iOS.m
commit de6e9fa2179ae17ec35a5c368d246f19da27f93a
Author: brone
Date: Wed Dec 8 22:37:54 2010 +0000
Moved R_DebugUI into runtime
~/projects/system/runtime/src%
(我也试过没有-M、-C和--find-copies-harder,但没有用。)
我可以在它的旧名称下获取它的历史记录,它会在它从旧位置被删除时停止:
~/projects% git log --summary --follow --find-copies-harder -M -C -- test/R_DebugUI_iOS.m
commit de6e9fa2179ae17ec35a5c368d246f19da27f93a
Author: brone
Date: Wed Dec 8 22:37:54 2010 +0000
Moved R_DebugUI into runtime
delete mode 100644 test/R_DebugUI_iOS.m
commit 32a22d53c27e260714f759ecb3d3864e38b2e87f
Author: brone
Date: Tue Dec 7 23:52:51 2010 +0000
Can set debug UI's alpha.
<<snip older commits>>
~/projects%
所以这次我并没有完全陷入困境,但我不希望一直做这种事情。 (我预计会有相当多的文件在其生命周期中至少移动一次。)
我做错了吗?文件的旧副本和新副本 98.8% 相同(166 行中有 2 行更改)。我的理解是,在这种情况下 git 应该能够跟踪文件,因为它推断重命名操作而不是显式存储它们,并且文件足够相似,我相信它应该认为它们是相同的。
有什么办法可以解决这个问题吗?
【问题讨论】:
-
猜猜:如果你在 ~/projects/ 里面执行命令而不是 ~/projects/system/runtime/src 会有效吗?
-
不,我得到了相同的结果。 (通常 git 似乎很适合让你在任何文件夹中......)
-
这给了我一个想法,我用我的发现更新了这个问题。感谢您的评论!
-
我在 mswindows 上使用“tortoiseGit 1.5.8.0”和“1.7.3.1.msysgit.0”。当我在资源管理器中重命名+提交文件时,我在我的 gui 中看到“状态 = 重命名”。我不太了解 git 如何在命令行中执行此操作来回答“如何执行此操作”,但 tortoiseGit 为我做了一些符合您预期的事情。
标签: git history dvcs rename git-log