我有一个跟踪svn存储库的git存储库。我使用--stdlayout
克隆了它。
我通过git checkout -b foobar
现在我希望这个分支最终位于svn存储库中的…/branches/foobar
。
我该怎么做?
(剪下了许多调查文本。如果你关心,请查看问题记录)
答案 0 :(得分:279)
我知道这个问题已经回答了一段时间,但在阅读之后,我可能会帮助添加特定git svn分支命令的示例并将其与典型的工作流程联系起来。
像kch一样回答,请使用git svn branch
。这是一个完整的例子,(请注意-n
用于干运行测试):
git svn branch -n -m "Branch for authentication bug" auth_bug
如果情况良好,服务器会回答如下答案:
将r8914的https://scm-server.com/svn/portal/trunk复制到https://scm-server.com/svn/portal/branches/auth_bug ...
如果没有-n
开关,服务器可能会添加如下内容:
找到可能的分支点:https://scm-server.com/svn/portal/trunk => https://scm-server.com/portal/branches/auth_bug,8914
找到分支父母: (参考文献/遥控器/ auth_bug)
d731b1fa028d30d685fe260f5bb912cbf59e1971
使用do_switch跟随父级
成功跟随父母r8915 = 6ed10c57afcec62e9077fbeed74a326eaa4863b8
(参考文献/遥控器/ auth_bug)
最好的部分,现在您可以根据您的远程分支创建一个本地分支,如下所示:
git checkout -b local/auth_bug auth_bug
这意味着“签出并创建名为auth_bug
的本地分支并使其跟随远程分支(最后一个参数)auth_bug
使用dcommit
--dry-run
(-n
)测试您的本地分支是否在该远程分支上运行:
git svn dcommit -n
SVN服务器应该回复新的分支名称:
致力于https://scm-server.com/svn/portal/branches/auth_bug ......
答案 1 :(得分:64)
从git v1.6.1开始,git svn branch
可用。
来自git docs:
branch Create a branch in the SVN repository. -m, --message Allows to specify the commit message. -t, --tag Create a tag by using the tags_subdir instead of the branches_subdir specified during git svn init.
以前版本的git没有提供创建svn分支的方法。
答案 2 :(得分:4)
@kch我刚刚(2008年12月7日)编译了git的v1.6.1-rc1标签,它确实包含了git svn branch命令及其文档。所以git的v1.6.1版本应该(希望)包含这个命令。