我正在使用git-svn来存储一些SVN仓库的"暂存"版本,允许其他用户从此暂存仓库中提取并提交更改回来,然后暂存仓库上的提交定期提交给上游SVN回购
我想知道是否有办法在git提交者的名字和SVN用户名之间进行映射,以便在提交回SVN回购时它们的信息将保持不变?
Von*_*onC 24
使用git svn时,Vincent Danen确实提到了-A选项:
因此,使用〜/ git作为Git存储库的顶级目录,可以
[...]创建authors.txt文件.
此文件将Subversion提交者的名称映射到Git作者,从而生成导入的Subversion存储库的正确历史记录.
对于具有少量提交者的项目,这非常简单.对于拥有大量提交者的大型项目,这可能需要一些时间.该文件的语法是:
user = Joe User <user@example.com>
vdanen = Vincent Danen <vdanen@somewhere.com>
短名称是Subversion的提交者名称,而长格式是用户的全名和电子邮件地址,由Git使用.
最后一步是克隆Subversion存储库,该存储库基于它创建一个本地Git存储库.假设您的存储库使用/ trunk,/ tags和/ branches的标准,请使用:
# git svn clone --no-metadata -A authors.txt -t tags -b branches -T trunk https://svn.example.com/svn/repo
-A<filename>
--authors-file=<filename>
语法与git-cvsimport使用的文件兼容:
loginname = Joe User <user@example.com>
如果指定了此选项并
git-svn遇到authors-file中不存在的SVN提交者名称,则git-svn将中止操作.
然后,用户必须添加适当的条目.修改authors文件后
重新运行上一个git-svn命令应继续操作.
config key: svn.authorsfile
这适用于所有git-svn命令,包括git-svn dcommit(当您推送到 SVN时)(注意:我没有直接测试它).
Mohammed Gamal确实报告(在评论中)它正在运作,但没有--no-metadata选择权.
| 归档时间: | 
 | 
| 查看次数: | 8450 次 | 
| 最近记录: |