8

我知道我可以从 git 存储库的目录中创建一个新的存储库。见这里:https ://help.github.com/articles/splitting-a-subfolder-out-into-a-new-repository/

但是,如何将目录从一个存储库复制到另一个完全不同的存储库的新目录,同时保留该目录的历史记录?

更新:该历史记录是否有可能与 git log 一起显示?

4

1 回答 1

8

你可以用git filter-branch. 基本上你会想要:

  1. 使用您已经找到的链接,将第一个项目中的子路径拆分到一个新的存储库中。
  2. 将其推送到唯一分支上的第二个项目的远程。
  3. 将该分支提取到第二个存储库中,然后用于git filter-branch将其索引过滤到正确的子目录中:

    git filter-branch --index-filter '
        git ls-files -sz | 
        perl -0pe "s{\t}{\tnewsubdir/}" |
        GIT_INDEX_FILE=$GIT_INDEX_FILE.new \
            git update-index --clear -z --index-info &&
            mv "$GIT_INDEX_FILE.new" "$GIT_INDEX_FILE"
    ' HEAD
    
  4. 最后,签出master第二个项目的分支(或您正在使用的任何分支),然后合并到新过滤的分支中。

真的不是太糟糕的手术,总而言之。正如 AlexanderGladysh 在评论中指出的那样,您还可以使用子树合并策略来代替步骤 3 和 4。

于 2012-09-08T01:36:30.730 回答