git-svn多branches路径

背景

最近,由于我的建议,组里采用开发分支与测试分支分离的方案,branches/*为测试分支,branches/dev/*为开发分支。问题来了,我本地的git-svn把整个dev目录别为一个分支,如何把dev目录底下的目录显示出来呢?

方案一(失败)

由于branches目录下,其他分支都是以一个统一前缀开头,通过在git-svn的配置下配置多个branches来实现区分。

branches = ^branches/prefix*:refs/remotes/origin/* # prefix分支统一前缀
branches = ^branches/dev/*:refs/remotes/origin/dev/*

执行git svn fetch,返回Invalid pattern in '^branches/prefix*': prefix的错误,可能是Ubuntu16.04上的版本比较老,不支持这种写法,在arch上是没有问题的。

方案二

依然是多个branches,但是通过ignore-refs参数控制,不让git-svn为dev目录创建分支。

branches = ^branches/*:refs/remotes/origin/*
branches = ^branches/dev/*:refs/remotes/origin/dev/*
ignore-refs = ^refs/remotes/origin/dev

这次成功忽略dev目录,并为dev目录底下目录创建dev/目录名的分支。

其他配置项

在查找解决方案时,研究了一下ignore-paths,include-paths:

  • ignore-paths: 忽略匹配到的路径,优先级比include-paths高
  • include-paths: 包含匹配到的路径,不匹配的路径会被忽略