zoukankan      html  css  js  c++  java
  • 多个git合并,并保留log历史记录

    面临的需求是:将多个git仓库作为一个单独目录,整合到一个新的git仓库中;并且保留历史记录。

    1. 新建一个summary仓库

    新建一个summary仓库,用于整合一系列git仓库。

    git clone <http_url>/summary.git
    cd summary
    touch README.md
    git add README.md
    git commit -m "add README"
    git push -u origin master

    2. 将其它git仓库merge到summary中

    git remote add alias_memory <http_url>/memory.git-------------------------将memory.git作为别名alias_memory加入到当前仓库中。
    git fetch alias_memory----------------------------------------------------从alias_memory拉取数据到summary仓库。
    git checkout -b branch_memory alias_memory/master-------------------------将alias_memory/master分支内容对checkout到summary仓库的branch_memory分支。。
    git checkout master-------------------------------------------------------切换到summary仓库的master分支。
    git merge branch_memory---------------------------------------------------将branch_memory分支合并到master分支。

    至此就将memory仓库的内容merge到了summary仓库中。

    但是此时summary中目录结构和memory一样,就需要将新建一个memory目录,并将memory仓库中对应文件移到summary仓库的memory目录中。

    mkdir memory
    git mv xxx memory--------------------------------------------------------这里面使用git mv要优于mv,git mv的结果就是一个rename操作。
    git commit -s -m "Merge memory.git to memory."
    git push -u origin master

    依次重复上面内容,即可将多个git仓库合并到summary中。

  • 相关阅读:
    Building Forest CodeForces
    欢迎使用CSDN-markdown编辑器
    Travelling HDU
    Card Collector HDU
    Doing Homework HDU
    Mirror Number SPOJ
    Palindromic Numbers LightOJ
    Magic Numbers CodeForces
    Xor-sequences CodeForces
    Little Elephant and Elections CodeForces
  • 原文地址:https://www.cnblogs.com/arnoldlu/p/11130600.html
Copyright © 2011-2022 走看看