SVN一些常用命令_svn diff url-程序员宅基地

技术标签: SVN  svn  

SVN 是什么?

SVN是Subversion的简称,是一个开放源代码的版本控制系统,相较于RCS、CVS,它采用了分支管理系统,它的设计目标就是取代CVS。互联网上很多版本控制服务已从CVS迁移到Subversion。


SVN的安装分客户端和服务端。

你可以在如下地址找到下 载:http://subversion.tigris.org/

这篇文章主要介绍的是svn 客 户端的命令,你至少需要安装客户端。默认就是以SVN 做版本控制的。如果你不想在自己机器上 安装服务版,google code是个练习svn 命令的好地方。

http://code.google.com上申请托管项目很简单,但 是现在不支持svn lock。目前最大支持1G空间。

 

以下是svn 客 户端常用命令一览:

svn add [path]

别名:无

描述:添加文件或目录到你的wc,打上新增标记。这些文件会在下一次你提 交wc的时候提交到svn 服务器。

在提交前,你也可以用svn revert撤销新增的文件。

访问库:否

eg: svn add file.cpp

 

svn blame Target[@REV]

别名:praise,annotate,ann

描述:显示某个已受控文件的每一行的最后修改版本和作者

访问库:是

eg: svn blame file.cpp

eg: svn blame --xml file.cpp  ##加上xml参数可以以xml格式显示每一行的属性

 

svn cat TARGET[@REV]

别名:无

描述:输出指定目标的内容,这里的目标一般是文件。

访问库:是

eg:svn cat file.cpp

eg:svn cat file.cpp -r 2 ##显示版本号为二的file.cpp内容。

eg:svn cat file.cpp --revision HEAD ##显示最新版本的file.cpp内容。

 

svn changelist CLNAME TARGET...

svn changelist --remove TARGET

别名:cl

描述:可以将wc中的文件从逻辑上分组.

访问库:否

eg:svn cl clName file.cpp file2.cpp file3.cpp  ##将file.cpp等三个文件加入名叫clName的changelist 

eg:svn commit --changelist clName -m "ci"  ##将clName下的所有文件提交

 

svn checkout URL[@REV]... [PATH]

别名:co

描述:检出

访问库:否

eg:svn checkout file:///var/svn /repos/test  file:///var/svn /repos/quiz working-copies

eg:svn checkout -r 2 file:///var/svn /repos/test mine  ##check out 版本号为2的项目

 

svn cleanup [PATH...]

别名:无

描述:递归的清理WC中过期的锁和未完成的操作。

访问库:否

eg:svn cleanup

 

svn commit [PATH...]

别名:ci

描述:把你WC的更改提交到仓库

访问库:是

eg:svn commit -m "added howto section." ##默认情况下提交必须提供log message


svn copy SRC[@REV]... DST

别名:cp

描述:copy操作可以从WC到WC;WC到URL;URL到 WC;URL到URL。现在SVN 只支持同一个仓库内文件的拷贝,不允许跨仓库操作。

访问库:是

eg:svn copy -r 11 file:///var/svn /repos/test/trunk /

           file:///var/svn /repos/test/tags/0.6.32-prerelease /

           -m "Forgot to tag at rev 11"

##copy命令是创建分支和标记的常用方式。copy到url的操作隐 含了提交动作,所以需要提供log messages。

 

svn delete PATH...

别名:del,remove,rm

描述:删除

访问库:如果PATH是库地址时会,删除WC内的文件不会。

eg:svn del localfile.cpp    ##删除WC里的文件,在下一次提交WC的时候才会真正在仓库里将对应文件删除。

eg: svn del file:///var/svn /repos/test/yourfile  ##删除仓库里的文件

 

svn diff

别名:di

描述:用来比较并显示修改点。

访问库:

eg:svn diff   ##最常用的方式,用来显示WC基于最近一次更新以后的所有的本地修改点。

eg:svn diff -r 301 bin ## 比较WC和版本301中的bin目录的修改点

eg:svn diff -r 3000:3500 file:///var/svn /repos/myProject/trunk   ##比较库里主干3000版和3500版的差异。

eg:svn diff --summarize --xml http://svn .red-bean.com/repos/test@r2 http://svn .red-bean.com/repos/test  ##--summarize --xml 参数将差异情况以xml文档的方式显示出来。

eg: svn diff --summarize -r 3000:3500 将两个版本之间的差异情况列出来

 

svn export [-r REV] URL[@PEGREV] [PATH]

svn export [-r REV] PATH1[@PEGREV] [PATH2]

别名:无

描述:导出一个干净的目录树,不包含所有的受控信息。可以选择从URL或 WC中导出。

访问库:如果访问的是URL则会。

eg:svn export file:///var/svn /repos my-export   ##导出到my-export目录

 

svn help — Help!

别名:?,h

描述:不用解释了

访问库:否。

 

svn import [PATH] URL

别名:无

描述:导入本地一个目录到库中。但是导入后,本地的目录并不会处于受控状 态。

访问库:是。

eg:svn import -m "New import base line"myproject http://svn .myProject.com/repos/trunk/misc

 

svn info [TARGET[@REV]...]

别名:无

描述:显示指定WC和URL信息。

访问库:仅当访问的是库路径时。

eg:svn info --xml http://svn .myProject.com/repos/test  ##将信息以xml格式显示。

 

svn list [TARGET[@REV]...]

别名:ls

描述:显示目标下的文件和目录列表。

访问库:如果访问的是库地址就会。

eg:svn list --verbose file:///var/svn /repos   ##--verbose参数表示显示详细信息。

 

svn lock TARGET...

别名:无

描述:对目标获得修改锁。如果目标已被其他用户锁定,则会抛出警告信息。 用--force参数强制从其他用户那里获得锁。

访问库:是

eg:svn lock --force tree.jpg

 

svn log [PATH]

svn log URL[@REV] [PATH...]

别名:无

描述:从库中显示log消息。log消息代码 A :added  D:deleted  M:modified  R:replaced

访问库:是

eg:svn log -v http://svn .myProject.com/repos/test/ foo.c bar.c   ##详细显示指定URL的库中foo.c和bar.c所有版本的log信息。

eg:svn log -r 14:15    ##显示当前WC的14和15版本log信息。

eg:##如果版本号不连续,只能采用如下方式。

svn log -r 14 > mylog

svn log -r 19 >> mylog

svn log -r 27 >> mylog

 

svn merge sourceURL1[@N] sourceURL2[@M] [WCPATH]

svn merge sourceWCPATH1@N sourceWCPATH2@M [WCPATH]

svn merge [[-c M]... | [-r N:M]...] [SOURCE[@REV] [WCPATH]]

别名:无

描述:合并两个受控源的不同之处,存放到一个WC里。

访问库:只有当访问库地址时。

eg:svn merge --reintegrate http://svn .example.com/repos/calc/branches/my-calc-branch  ##合并分支上的改变项到WC,往往用于分支合并到主干。

eg:svn merge -r 156:157 http://svn .example.com/repos/calc/branches/my-calc-branch   ##将制定URL版本156到157的所有更新合并到WC

 

svn mkdir PATH...

svn mkdir URL...

别名:无

描述:在WC或库路径创建目录

访问库:只有当访问库地址时。

eg:svn mkdir newdir

 

svn move SRC... DST

别名:mv, rename, ren

描述:等同于svn copy命令跟个svn delete命令。WC到URL的重命名是不被允许的。

访问库:只有当访问库地址时。

eg:svn move foo.c bar.c  ##将foo.c改名成bar.c。

 

svn propdel PROPNAME [PATH...]

svn propdel PROPNAME --revprop -r REV [TARGET]

别名:pdel, pd

描述:从受控文件,目录等删除属性。第二种是删除某个指定版本上的附加属 性。

访问库:只有当访问库地址时。

eg:svn propdel svn :mime-type someFile    ##从someFile上移除svn :mime-type这个属性。

 

svn propedit PROPNAME TARGET...

svn propedit PROPNAME --revprop -r REV [TARGET]

别名:pedit, pe

描述:编辑属性

访问库:只有当访问库地址时。

eg:svn propedit svn :keywords  file.c  ##修改file.c上的svn :keywords属性。

 

svn propget PROPNAME [TARGET[@REV]...]

svn propget PROPNAME --revprop -r REV [URL]

别名:pget,pg

描述:从文件,目录或版本取得指定属性的值。

访问库:只有当访问库地址时。

eg:svn propget svn :keywords file.c   ##从file.c中取得svn :keywords属性的值

 

svn proplist [TARGET[@REV]...]

svn proplist --revprop -r REV [TARGET]

别名:plist, pl

描述:列出文件、目录或版本上的所有附加属性

访问库:只有当访问库地址时。

eg:svn proplist --verbose file.c

 

svn propset PROPNAME [PROPVAL | -F VALFILE] PATH...

svn propset PROPNAME --revprop -r REV [PROPVAL | -F VALFILE] [TARGET]

别名:pset,ps

描述:给文件、目录或版本附加属性并赋值

访问库:只有当访问库地址时。

eg:svn propset svn :mime-type image/jpeg file.jpg   ##给file.jpg附加属性svn :mime-type 其值为image/jpeg

eg:svn propset --revprop -r 25 svn :log "Journaled about trip to New York."

##给版本25补上log message

eg:svn propset svn :ignore '.classpath' . 

##在本地忽略掉.classpath文件

 

svn resolve PATH...

别名:无

描述:将冲突的文件标记为已解决,并且删掉冲突产生的临时文件。注意这个 命令并不是能把冲突解决,解决冲突还是得靠人工。

访问库:否

eg:svn resolve --accept mine-full foo.c   ##1.5版本后,加上--accept参数,尝试自动处理冲突

 

svn resolved PATH...

别名:无

描述:已过时,被resolve --accept取代。去除冲突的状态和冲突临时文件。

访问库:否

 

svn revert PATH...

别名:无

描述:还原WC中所有的本地更改。

访问库:否

eg:svn revert --depth=infinity .   ##将整个目录所有文件还原

 

svn status [PATH...]

别名:stat, st

描述:输出WC中文件和目录的状态。如果WC提交,这些状态就会同步到库 里。

一般状态有         ' '  没有修改

'A'  新增

'D'  删除

'M'  修改

'R'  替代

'C'  冲突

'I'  忽略

'?'  未受控

'!'  丢失,一般是将受控文件直接删除导致

访问库:加上--show-updates参数时会

eg:svn status wc

 

svn switch URL[@PEGREV] [PATH]

svn switch --relocate FROM TO [PATH...]

别名:sw

描述:将WC转向一个其他的库地址同步

访问库:是

eg:svn sw http://svn .myProject.com/repos/trunk/vendors .  ##将当前WC切换到另一个URL

 

svn unlock TARGET...

别名:无

描述:解锁

访问库:是

eg:svn unlock somefile

 

svn update [PATH...]

别名:up

描述:更新WC,更新反馈有如下几种分类。

A  新增

B  锁破坏

D  删除

U  更新

C  冲突

G  合并

E  存在的

访问库:是

eg:svn up -r22   ##更新到一个指定版本

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/shineflowers/article/details/41721341

智能推荐

博鳌亚洲论坛2023年会 国研政情·谋定论道-桑切斯:中欧合作行动-程序员宅基地

文章浏览阅读326次,点赞8次,收藏8次。博鳌亚洲论坛2023年会 国研政情·谋定论道-桑切斯:中欧合作行动

史上最全的Android面试题集锦,知乎上已获万赞_android 面试题库 知乎-程序员宅基地

文章浏览阅读99次。背景知乎客户端中有一个自己维护的 Hybrid 框架,在此基础上开发了一些 Hybrid 页面,当需要前端或者客户端开发接口的时候,就涉及到联调的问题。和一般的 前端 <=> 服务端,或者 客户端 <=> 服务端 类似,前端 <=> 客户端也会出现联调的各种问题,但是往往 Hybrid 开发相关的调试工具并不是那么完备。由于在 Hybrid 里面,前端和客户端联系是很紧密的,假如一个人既熟悉前端开发又熟悉客户端开发,调试是很容易的,但是现实一般是可能客户端开发并不是_android 面试题库 知乎

SpringBoot多模块项目打包_spingboot添加多个启动项目分别打包-程序员宅基地

文章浏览阅读269次。SpringBoot多模块项目打包_spingboot添加多个启动项目分别打包

【微电网优化】基于matlab YALMIP求解微网(光伏+风电+蓄电池+微电网+柴油机)优化调度问题【含Matlab源码 2266期】_matlab虚拟电厂调度优化-程序员宅基地

文章浏览阅读596次。YALMIP求解微网(光伏+风电+蓄电池+微电网+柴油机)优化调度问题完整代码,直接运行,适合小白!可提供运行操作视频!_matlab虚拟电厂调度优化

vue3 中使用el-dropdown时,slot报错`slot` attributes are deprecated_vue3 `slot` attributes are deprecated.-程序员宅基地

文章浏览阅读1k次,点赞3次,收藏4次。在VUE3中使用el-dropdown时,出现了下面的报错是因为vue 3.x 增加了v-slot的指令,去掉了原来的slot,slot-scope属性。el-dropdown-menu标签外面加上如下图:<el-dropdown> <span class="el-dropdown-link"> 下拉菜单<i class="el-icon-arrow-down el-icon--right"></i> </span>_vue3 `slot` attributes are deprecated.

ioc和di的关系-程序员宅基地

文章浏览阅读6.5k次,点赞6次,收藏9次。 刚进入spring的时候,看见这两个词一阵迷茫,控制反转不知道转的是啥,依赖注入也不知道注入的啥。有的人说这两个是一个,有的说di是ioc的实现,我就说说我的理解。 从getter和setter开始 从开始学习mvc设计模式,或者是jsp异或是框架,必然会有JavaBean或者其他类似的概念出现。getter和setter就是JavaBean中的..._ioc和di的关系

随便推点

7年点工,从为娶媳妇开始软件测试,到最后拍领导桌子甩头辞职···_软件测试纯点工-程序员宅基地

文章浏览阅读274次。7年的点工测试,薪资从1800到4500再到15K,为了让媳妇过得更好,决定来学自动化,实现买买买自由的初步小目标。_软件测试纯点工

记录MEMORY_MANAGEMENT蓝屏解决过程_ntoskrnl.exe memory_management-程序员宅基地

文章浏览阅读3.9w次,点赞10次,收藏45次。MEMORY_MANAGEMENT蓝屏解决过程问题描述win10,1909版本,一个月内蓝屏两至三次,都是在空闲时蓝屏,提示MEMORY_MANAGEMENT仅安装火绒,内存4+16(crucial,2666,后配的)解决过程首先我检查了下硬件,内存和硬盘没发现问题另排除病毒使用Debugging tools查看DMP文件,发现是由于ntoskrnl.exe导致命令提示符下执行chkdsk c: /f,重启修复c盘原因分析引用1:ntoskrnl.exe 是 Windows 操作系统的_ntoskrnl.exe memory_management

java开发工具包jdk包括哪些_java的工具包有多少兆代码-程序员宅基地

文章浏览阅读679次。害怕干不过SpringBoot?莫慌,我送你套神级pdf文档随着 Spring Boot 使用越来越广泛,Spring Boot 已经成为 Java 程序员面试的知识点,很多同学对 Spring Boot 理解不是那么深刻,经常就会被几个连环追问就给干趴下了!今天小编就给大家整理了全套SpringBoot“神级PDF文档”:面试篇:35常见知识点、21道必刷题、10个高频解析题知识脑图篇:综合解析SpringBoot知识大全预览进阶学习必备篇:《SpringBoot学习教程》、《深入_java的工具包有多少兆代码

java基础案例教程黑马程序员案例答案,真香_springboot黑马程序员课后答案-程序员宅基地

文章浏览阅读2.3k次。掌握核心知识1、90%几率面试被问,吃透原理,面试不慌(Spring原理)2、大厂必问Redis,赶紧码起来(Redis核心原理)3、MySQL从入门到实战都在这篇,面试笑谈优化当然核心知识不止这三点,这只是一部分吃透源码1、面试源码有捷径,Spring源码将无所畏惧(Spring源码解析)2、金三银四面试必问,MyBatis二级缓存揭秘3、面试加分课,Spring MVC源码将无所畏惧实战训练1、受用终生的Redis实战场景2、面试加分项(Spring Boot实战_springboot黑马程序员课后答案

如何完全删除解压版mysql_Mysql Window 解压版卸载-程序员宅基地

文章浏览阅读690次。windows如何彻底卸载mysql如何彻底删除mysql1.首先在windows服务中将mysql服务删掉,使用命令 sc delete mysql2.在控制面板中卸载掉mysql。3.清理mysql安装目录的ini文件。4.清理注册表:HKEY_LOCAL_MACHINE\SYSTEM\ControlSet001\Services\Eventlog\Application\MySQL 目录删除..._windows怎么卸载解压版的mysql

linux安装mariadb数据库_linux a安装mariadb-程序员宅基地

文章浏览阅读1.5k次。1. 在linux系统安装mariadb数据库命令:yum install mariadb-server -- 安装mariadb数据库如果安装失败执行此命令:yum clean all 2. 确认下载:3. 安装成功提示:4. 数据库命令: 1. 启动命令 [root@localhost src]# systemctl start mariadb 2. 重启命令 [root@localhost src]# ..._linux a安装mariadb

推荐文章

热门文章

相关标签