我已经将SVN存储库导入到新的git裸存储库中。
我的标签被转换成git标签,但我有这条git公路线:

有什么方法可以把所有的东西都带回到主程序中的一行吗?
就像这样:

(我是git的初学者)
提前感谢
发布于 2017-01-31 14:50:19
您所要做的就是将标记移动到正确的提交(它们的父提交)。您可以使用以下命令一个接一个地手动执行此操作:
git tag -f v2.8.0 v2.8.0~1将v2.8.0替换为每个标记的名称。
如果有许多标记要移动,您可以使用git tag -l > tags.txt生成它们的列表,并将其保存到tags.txt文件中。在文本编辑器中打开文件并删除不想修改的标记(如果问题中的图像显示当前历史记录行,则只有v2.8.2和v2.8.3正确放置;从文件中删除它们)。保存文件,然后运行:
for t in $(cat tags.txt); do git tag -f $t ${t}~1; done它将处理文件中的所有标记。
更新:
为了将标记的更新位置推送到上游存储库,运行:
git push --force --tags origin将origin替换为要推送标记的所有远程存储库的名称。
发布于 2017-01-31 15:00:56
git-svn是,而不是,是存储库或存储库部件一次性转换的合适工具。如果您想使用Git作为现有SVN服务器的前端,这是一个很好的工具,但是对于一次性转换,您应该使用而不是使用git-svn,而是更适合这种用例的svn2git。
从您的截图中我可以看到,您很可能使用了一个基于git-svn的工具,比如nirvdrum svn2git,因为这些“标记分支”是使用git-svn的缺点之一。
有很多叫做svn2git的工具,最好的工具可能是来自https://github.com/svn-all-fast-export/svn2git的KDE工具。我强烈建议使用该svn2git工具。这是我所知道的最好的,而且它非常灵活,您可以使用它的规则文件。
您可以很容易地配置svn2git的规则文件,以便在历史记录中生成您想要的结果,或者将所有SVN子repos集成在一个Git中,或者将您的项目从SVN拆分到多个独立的Git存储库。
如果您对存储库的历史没有100%的了解,那么svneverever来自http://blog.hartwork.org/?p=763是一个很好的工具,可以在将它迁移到Git时研究它的历史。
尽管git-svn一开始更容易,但以下是使用KDE svn2git而不是git-svn的更好的原因,除了它的灵活性之外:
svn2git重建得更好、更干净(如果使用正确的历史),尤其是对于具有分支和合并等更复杂历史的历史。git-svn时,标记包含额外的空提交,这也使得它们不属于分支,所以在将--tags交给命令之前,普通的fetch不会得到它们,因为在默认情况下,也只获取指向获取分支的标记。使用适当的svn2git标记是它们所属的位置svn2git配置这个布局,而使用git-svn,您最终会丢失历史记录。svn2git,您还可以轻松地将一个SVN存储库拆分为多个Git存储库。svn2git转换比使用git-svn快很多倍。git-svn更差、KDE svn2git更优越的原因有很多。:-)
https://stackoverflow.com/questions/41960263
复制相似问题