我有四个独立的项目。他们有自己的git存储库。所有项目的分支机构名称相同。
/project/
/project/projA/
/project/projA/.git/
/project/projB/
/project/projB/.git/
/project/projC/
/project/projC/.git/
/project/projD/
/project/projD/.git/
所有git存储库都有相同的分支名称,当然还有它们自己的主分支。
问题
我想将所有项目合并为一个项目,如下所示:
/Project/.git/
/project/projA/
/project/projB/
/project/projC/
/project/projD/
但
我想保留所有分支的历史记录。
ps ->我对所有存储库都有相同的分支名称。例如:用于所有四个项目的分支名称: V6-004
详细信息
我尝试了子模块和子树,但这两者都不能解决问题。
我也试过这个。
$ mkdir new_parent_project
$ cd new_parent_project
$ git init
# Now we need to create the initial commit. This is essential.
$ touch README.md
$ git add README.md
$ git commit -am "initial commit"
之后
# merge project ProjA into subdirectory ProjA
$ git remote add -f ProjA http://GitUrl
$ git merge -s ours --no-commit ProjA/V6-006
$ git read-tree --prefix=ProjA/ -u ProjA/V6-006
$ git commit -m "merging ProjA into subdir: ProjA"
之后
# merge project ProjB into subdirectory ProjB
$ git remote add -f ProjB http://GitUrl
$ git merge -s ours --no-commit ProjB/V6-006
$ git read-tree --prefix=ProjB/ -u ProjB/V6-006
$ git commit -m "merging ProjB into subdir: ProjB"
但
项目合并了,但我只有V6-006的历史。但我没有其他分支机构的历史记录。
发布于 2014-10-22 22:31:42
这个解决方案与您尝试的相距不远。只有当您的不同项目没有公共文件时,这才有效(否则很难解决冲突)
# create a new repo:
git init all_projects
cd all_project
# to make it more easy to understand, let's create a new branch
git checkout -b main
# import 1st project
git remote add projectA http://projectA
git fetch --all --tags
git checkout masterA projectA/master
git rebase masterA main
# move the main branch to the current state
git branch main -f
# Now your branch main is at the same state as your A project
# import 2st project
git remote add projectB http://projectB
git fetch --all --tags
git checkout masterB projectB/master
git rebase masterB main
# move the main branch to the current state
git branch main -f
# Now your branch main contains all commits from projectA and projectB
# etc..
结果将是一个存储库,首先是来自项目A的所有提交,然后是来自项目B的所有提交,即使项目B在项目A的最后一次提交之前有一些提交,但这应该不是问题(并且历史树将更容易读取)
编辑:抱歉,我只是注意到这并不能解决你获取所有远程分支的问题。也许你可以找到一个基于that question的解决方案,如下所示:
for i in $(git branch -r |grep projectA|awk -F'/' '{print $2}'); do
git checkout $i projectA/$i
git rebase $i main
done
但这将使您的树更加复杂,因为所有分支都将从main
提交开始。
https://stackoverflow.com/questions/26502970
复制相似问题