使用Git-Svn克隆非标准Svn存储库

时间:2009-02-21 12:28:39

标签: svn git git-svn clone

我对Git比较陌生,但我发现在家工作很容易,我想在我们的项目存储在Svn存储库中的工作中使用它。不幸的是,存储库略微不标准,我无法克隆它们。当然,它们都有trunk,branches /和tags /,但是分支/和标签/有子目录,然后才能访问真正的项目目录:

trunk/
branches/maintenance/release1
branches/maintenance/release2
...
branches/development/feature1
branches/development/feature2
...
tags/build/build1
tags/build/build2
...
tags/release/release1
tags/release/release2

克隆后:

$ git svn clone -s --prefix=svn/ https://mydomain.com/svnproject
$ git branch -r
  development
  development@1340
  maintenance
  maintenance@1340
  tags/build
  tags/build@1340
  tags/release
  tags/release@1340
  trunk
  trunk@1340 

我没有得到任何实际的项目分支或标签。我实际上需要能够在主干,一个维护分支和一个开发分支上工作。我已经尝试过这种方法,除了修改配置的几个黑客,但没有什么对我有用。

有什么方法可以将我的非标准Svn项目的关键组件放到本地git存储库中,以便我可以轻松地在它们之间移动?

非常感谢。

更新:我应该补充一点,我不能批量切换到Git(还)。还有其他团队成员参与和国际存在。转型的后勤工作比我更愿意承担,直到我对Git更加满意;正如我所提到的,我还是很新的。我几乎没有表现出它的能力。

3 个答案:

答案 0 :(得分:34)

李B是对的。 doener在#git中提供的答案是将Git升级到1.6.x(我一直在使用1.5.x)。 1.6.x提供深度克隆,以便可以使用--branches选项使用多个通配符:

$ git svn clone https://svn.myrepos.com/myproject web-self-serve \ 
          --trunk=trunk --branches=branches/*/* --prefix=svn/
$ git branch -r
  svn/development/sandbox1
  svn/development/feature1
  svn/development/sandbox2
  svn/development/sandbox3
  svn/development/model-associations
  svn/maintenance/version1.0.0
  svn/trunk

正是我所需要的。感谢所有人的洞察力。

答案 1 :(得分:13)

您可以尝试nirvdrum's svn2git(似乎是最新的)将svn导入git存储库吗?
(2009年初,Paul提到了这个 iteman's svn2git 来代替这个original jcoglan's svn2git,正如他的作者所提到的那样:“快速破解我的代码 Subversion“)

它比git svn clone好,因为如果你在svn中有这个代码:

  trunk
    ...
  branches
    1.x
    2.x
  tags
    1.0.0
    1.0.1
    1.0.2
    1.1.0
    2.0.0

git-svn 将通过提交历史记录来构建新的git repo。
将所有分支和标签导入为远程svn分支,而你真正想要的是git-native本地分支和git标记对象
因此,在导入此项目后,您将获得:

  $ git branch
  * master
  $ git branch -a
  * master
    1.x
    2.x
    tags/1.0.0
    tags/1.0.1
    tags/1.0.2
    tags/1.1.0
    tags/2.0.0
    trunk
  $ git tag -l
  [ empty ]

在你的项目完成svn2git之后,你会得到这个:

  $ git branch
  * master
    1.x
    2.x
  $ git tag -l
    1.0.0
    1.0.1
    1.0.2
    1.1.0
    2.0.0

当然,这个解决方案并不是单程旅行。

您可以随时返回到您的svn存储库,其中包含... git2svn (还有present there

这个想法仍然存在:

  • SVN作为中央存储库工作。

  • Git“在其他地方”快速在多个Git私人分支机构中进行实验。

  • 导回 仅将Git分支机构合并到官方SVN分支机构。

答案 2 :(得分:9)

对于普通通配符不提供的回购布局:(从my answerthis related question

current git-svn manpage说:

  

也可以获取子集   分支或标签使用   以逗号分隔的名称列表   括号。例如:

[svn-remote "huge-project"]
     url = http://server.org/svn
     fetch = trunk/src:refs/remotes/trunk
     branches = branches/{red,green}/src:refs/remotes/branches/*
     tags = tags/{1.0,2.0}/src:refs/remotes/tags/*