git仓库中克隆文件同时保存line history / 行提交历史的方法介绍

问题介绍

在大型单体git仓库中,有时需要拷贝文件,并在原文件和新文件上继续迭代。一般情况下,简单的复制或git mv + git restore都只能保留两份文件的file history,而line history只能保留一份文件的。

这是因为git的file history关联是基于文件内容的相似度检测的,较为宽松。而line history的关联更加严格,需要检测到明确的继承关系。

如果想要都保留可参考下面的方法。

解决方法

假设在当前master分支我们想要克隆Foo文件夹。

  1. 移动原文件,建立新分支
shell 复制代码
git mv Foo Foo-clone
git checkout -b fake
git commit -m "clone Foo"

在这一步中,我们通过git mv命令让git在两次提交间确立Foo和Foo-clone的继承关系。

  1. 恢复原文件
shell 复制代码
git checkout HEAD^ -- Foo
git commit -m "restore Foo"

这一步的目的是让fake分支中Foo文件夹的内容与master分支保持完全一致,避免在第三步merge时git将Foo和Foo-clone合并。此时Foo在该分支没有上级继承。

  1. 切回master分支,合并fake分支
shell 复制代码
git switch master
git merge fake --no-ff	# 注意防止fast forward直接强推至fake

在master分支中,Foo有上级继承;在fake分支中,Foo-Clone有上级继承,因此这里通过合并分支,可以让合并后结果中两个文件夹都有上级继承,从而都保留了line history。

总结

核心原理就是根据git检测line history关联的逻辑,特意去制造两份文件的上级继承关系。

OK,要是在实操中遇到问题,欢迎留言或发邮件to fyli88@qq.com

相关推荐
kyriewen4 小时前
别再每次都 Google 了:我整理了前端日常最常踩的 10 个 Git 坑,附速查表
前端·javascript·git
A_Lonely_Cat2 天前
记一次 GitHub 幽灵协作者大清洗:强制重写 Git 历史与穿透 CDN 缓存实践
git·github
和你看星星4 天前
Git rerere:让重复冲突只解决一次
git
嘻嘻仙人8 天前
Ubuntu中 git上传自己的项目和二次上传一般流程
git·github
Patrick_Wilson8 天前
Squash Merge 的血缘陷阱:为什么删掉的代码又活了过来
前端·git·程序员
沉浸学习的匿名网友8 天前
什么是 .gitignore?为什么每个 Git 项目几乎都离不开它?
前端·git
深海鱼在掘金9 天前
Git 完全指南 —— 第3章:理解工作区、暂存区、版本库三个核心
git
江华森9 天前
Git 基础筑基:从原理到团队协作的全栈实战
git
JakeJiang9 天前
Git 必备命令指南:从日常高频到项目开发实战
git
叫我少年10 天前
Windows 中安装 git
git