合并两个git仓库,并保留每个仓库的历史

来源:互联网 发布:启动mysql错误1067 编辑:程序博客网 时间:2024/05/01 11:58

     问题:有两个git仓库 repository1和repository2,想把repository2合并到repository1,并在repository1中保留repository2的所有分支历史

   方案:  1.在repository1中添加远程分支,,跟踪repository2,并把repository2全部分支拉到repository1中,命令为:

                 git  remote add other /path/to/repository2

                 git fetch other

                  2.第一步执行完后,在repository1工作目录中.git/refs/remotes/ 文件夹下有个other文件夹,ohter文件夹里是所有的repository2分支,因此只要把这些分支设置成repository1分支即可,命令为:

                  for branch in `ls .git/refs/remotes/ohter`

                  do

                       if test "${branch}"="master"

                       then

                           git checkout -b othermaster other/${branch}

                        else

                           git checkout  -b ${branch} other/${branch}

                       fi

                    done

       参考:http://stackoverflow.com/questions/1683531/how-to-import-existing-git-repository-into-another

原创粉丝点击