详解Linux上svn命令行批量操作
详解Linux上svn命令行批量操作
虽然说git很好,大多数时候我也是使用git,但是有时候因为一些原因,不得不使用svn,而在linux上使用svn是没有像windows上的tortoisesvn的软件的(网上有说有类似的,但是折腾了很久仍然没有成功),所以直接来命令行吧。
我们直接安装svn就好,然后文件修改之后使用命令
?1 | svn status |
查看文件的跟踪信息,这里会使用一些代号,对应的大概是
?1 2 3 4 5 6 7 8 9 10 11 12 13 | “ ” 无修改 “A” 新增 “C” 冲突 “D” 删除 “G” 合并 “I” 忽略 “M” 改变 “R” 替换 “X” 未纳入版本控制,但被外部定义所用 “?” 未纳入版本控制 “!” 该项目已遗失 (被非 svn 命令所删除) 或是不完整 “~” 版本控制下的项目与其它类型的项目重名 |
这里我们需要考虑的是“缺失”和“未纳入版本控制“,也就是”!“和”?“,直接使用下面的命令即可
?1 2 | svn add `svn status | grep ? | awk '{print $2}' ` svn delete `svn status | grep ! | awk '{print $2}' ` |
注意命令中的反引号,是”esc“键下面,”1“旁边的那个,表示一个命令。
使用上面的命令之后,对应的文件的状态就会变成对应的“D”和“A”,然后就可以使用命令
?1 | svn commit -m "xxxx" |
进行提交了!
这里提到的两种命令操作对于文件明中存在空格的情况会出问题
如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
原文链接:https://my.oschina.net/songxinqiang/blog/543132
1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。