3

我正在尝试将我的 svn 存储库切换到 git。这是一个旧存储库,以前的维护者之一为每个新版本移动了主干。例如,以前的存储库位于:

  • svn+ssh://svn.mycompany.com/project/release_1/trunk

现在,我们当前的主干位于:

  • svn+ssh://svn.mycompany.com/project/release_N/trunk

当我签出 SVN 第二个存储库时,我有完整的历史记录,包括在复制之前。但是,当我 git-svn 第二个存储库时,我没有旧的历史记录(来自 release_1,...)。第一次提交是release_{N-1}to的副本release_N/trunk

这是我尝试过的:

  • git svn clone --no-minimize-url --authors-file my-authors-file svn+ssh://svn.mycompany.com/project/release_N/trunk my_project.git

由于这不起作用,我尝试了其他方法。假设“复制提交”是 K,我试过:

  • git svn clone --no-minimize-url -r BASE:K --authors-file my-authors-file svn+ssh://svn.mycompany.com/project/release_N/trunk my_project.git

这次 git-svn 没有找到任何提交。

你知道是否有一个神奇的技巧来拥有完整的历史吗?

4

1 回答 1

1

这就是我对这个问题的理解:
您的历史分布在几个 svn 分支(恰好都称为主干)。当你迁移到 git 时,你会想要所有这些历史。

我认为以下将解决您的问题:

git svn init my_project.git

git config svn-remote.svn.url svn+ssh://svn.mycompany.com/project
git config svn-remote.svn.fetch release_N/trunk:refs/remotes/trunk
git config svn-remote.svn.branches */trunk:refs/remotes/*
git config svn.authorsfile my-authors-file

git svn fetch

这会将 release_N 分支创建为主干,并将其余版本创建为 git 存储库中的不同分支。

据我所知,你不能让一个 git svn 分支指向多个 url,我认为这是你想要做的。

于 2013-10-17T08:07:28.087 回答