我使用保存在svn中的软件进行版本控制。我想使用git(git-svn),但是该软件在使用前需要大量的设置和配置。有些工具可以处理所有的设置,包括通过svn检查所有的代码。将SVN签出转换为使用git(git-svn)
git-svn的所有文档(我已经能够找到)需要使用git-svn进行全新的结帐。
有没有办法将现有的svn checkout转换为可以使用git-svn?
我使用保存在svn中的软件进行版本控制。我想使用git(git-svn),但是该软件在使用前需要大量的设置和配置。有些工具可以处理所有的设置,包括通过svn检查所有的代码。将SVN签出转换为使用git(git-svn)
git-svn的所有文档(我已经能够找到)需要使用git-svn进行全新的结帐。
有没有办法将现有的svn checkout转换为可以使用git-svn?
你可以做这样的事情:
编号git-svn克隆将整个存储库转换为git。 SVN签出没有整个存储库,因此无法从中克隆。这是从SVN或CVS切换到分布式系统(如git)的主要优势。
另一种方式来做到这一点,它不修改原始Subversion工作拷贝,也不需要你复制它,使用补丁:
git reset --hard :/r<revision>
强制它在克隆后进行相同的修订,其中<revision>
是Subversion工作副本更新到的修订版(请参阅此处使用svn info
)。cd
到您的Subversion工作副本。svn status
,以确保所有的新文件都标有A
(或使用svn add
添加它们),所有被删除的文件标有D
(或使用svn rm
删除它们)。svn diff >patch.diff
创建补丁文件。patch.diff
复制到之前创建的Git存储库的顶部。cd
到之前创建的Git存储库的顶部。git apply -p0 patch.diff
将补丁应用于Git存储库的工作树上。现在,你可以通过使用git status
的变化,和git add
/git commit
它们,将它们保存在您的本地仓库。
我假设你可能想保留历史。但是,如果您(或任何其他人在此页面上绊倒)不需要历史记录,则可以使用“导出”功能,如下所述:https://stackoverflow.com/a/419475/2437521。
我不关心所有的历史,只是当它检查出svn时的状态,以及svn分支上的未来更改(所以我从调用git-svn rebase得到的) – Jachin 2009-05-05 21:16:22
这不是git的工作原理。 DVCS是“分布式”的,因为每个克隆都是存储库的完整副本。这就是整个问题。 – singpolyma 2009-05-05 21:53:58