相关疑难解决方法(0)

是否可以在Git中移动/重命名文件并保留其历史记录?

我想在Git中重命名/移动项目子树

/project/xyz
Run Code Online (Sandbox Code Playgroud)

/components/xyz
Run Code Online (Sandbox Code Playgroud)

如果我使用普通的git mv project components,那么所有的提交历史xyz project都会丢失.有没有办法移动这个以保持历史?

git rename mv

630
推荐指数
11
解决办法
32万
查看次数

Git重命名文件.历史记录在cmd-line上可用,但在github界面中没有?

在Git中重命名文件和文件夹时,有很多 关于如何保存历史记录的优秀 帖子.


这适用于git命令行界面:

#if you don't modify oldname.cpp or newname.cpp, git will understand your rename

git mv old.cpp new.cpp
git commit -am "renamed old.cpp -> new.cpp"

git log new.cpp #only shows the new commit
git log --follow new.cpp #shows ALL the history of old.cpp and new.cpp
Run Code Online (Sandbox Code Playgroud)

太棒了,所以这个--follow命令允许我们new.cpp在重命名之后获得所有的历史记录.这在git的命令行界面中效果很好.


但是,在github web界面中,历史old.cpp并未显示出来new.cpp.这是一个问题,因为我的许多团队成员都将他们的github帐户视为简历的一部分.如果他们的提交在重命名文件后没有出现在github中,那么他们就会失去恢复点.在主要文件名/目录重构之后,贡献者最终可能没有在repo上进行单个可见提交.

git log --follow在重命名文件后,如何在github Web界面(例如)中显示完整的文件历史记录?

或者我不会重命名任何东西,除非我愿意让偶然的github用户永远不会看到旧的提交?

git version-control github

8
推荐指数
1
解决办法
3532
查看次数

标签 统计

git ×2

github ×1

mv ×1

rename ×1

version-control ×1