我试图重命名一个项目和它的模块,然后放在不同的文件夹中。例如:
公司A-模组1到projecta模组1和公司A模组2到projectb模组2
然后将这些重命名的模块放到不同的新文件夹中。在经历了所有这些变化之后,现在我要从一开始就保存历史。有可能吗?如果是,我怎样才能做到这一点?谢谢。
发布于 2019-12-17 13:54:52
移动存储库中的目录
git有一个mv命令,它允许您移动目录,保留历史记录。
git mv companya-module1 projecta-module1
git mv companya-module2 projectb-module2这个阶段以renamed的形式工作,您必须提交此更改。
将目录移动到新的存储库
您可以为此使用filter-branch,它在结构中接受一个directory,并仅使用该目录创建一个新的提交。
git clone git://github.com/user/repo.git
git filter-branch --subdirectory-filter companya-module1 -- -- all注意,这将删除除该目录之外的所有其他文件的内容。
git子树分裂
最后,git添加了subtree-split来帮助这一点。使用下面的代码来subtree split project1回购中的一个特定文件夹,并使用该工作创建一个分支。
cd project1
git subtree split -P companya-module1/ -b companya-module1一旦您准备好将其放入到它自己的回购中,就可以从project1回购和指定的分支中提取该分支(本地)。
cd ..
mkdir companya-module1
cd companya-module1
git init
git pull ../project1 companya-module1您应该得到的是一个新的目录/ repo,其中包含project1中该目录的内容。
https://stackoverflow.com/questions/59375693
复制相似问题