转载自http://www.codelast.com/?p=5719
(1)查看日志
提交的时候一般会写上注释,如果要查看提交日志,用以下命令:
1
|
svn log -l 4
|
其中,-l 4表示只查看最近4条日志(也可以没有这样的参数,就表示查看所有日志)。但是你通常会很抓狂地发现,最近的几条日志中,竟然没有你才刚刚提交的那一次的日志!这是怎么回事?日志丢了吗?
其实,是因为你要很用以下命令,更新本地的版本库,才能看到最近提交的日志:
1
|
svn up
|
这事如果你没注意到,那么可能会浪费你很多时间。问Google也不好找答案,因为这个问题不太好描述,所以不好搜索答案。
(2)查看指定的版本修改了哪些文件
1
|
svn
diff
--summarize -c 566
|
其中,566是你指定的版本。
(3)查看某个文件在指定的版本修改了什么内容
1
|
svn
diff
Test.java -c 566 > codelast.
diff
|
其中,Test.java是你要检查的文件,566是你指定的版本,最后diff被输出到了codelast.diff文件中。
(4)提交
1
|
svn ci -m
"Your comment"
|
其中,Your comment 就是你填写的注释,如果你想换行写,也是可以的,只要你不写后面的那个引号,你可以写一行就回车一次,最后写完了,再加上后面的引号,然后再回车,就执行提交动作了。
(5)检出指定版本的版本库
1
|
svn co https:
//xxx
-r 566
|
其中,https://xxx 是你的版本库地址,566是你要检出的版本号。版本库将被检出到当前路径下。
文章来源:http://www.codelast.com/
(6)将指定version的trunk上的代码拷贝到tags的指定目录下
1
|
svn
cp
https:
//svn
.codelast.com
/trunk/my-project
@1333 https:
//svn
.codelast.com
/tags/my-project-r1333
|
如上命令将trunk下的 my-project 项目的 1333 版本拷贝到了tags下的 my-project-r1333 中。
(7)将branches上的指定版本合并(merge)到trunk上
有时候我们会在一个分支(branches)上开发,等开发完成的时候,需要把我们已经提交到branches上的代码合并到trunk上,假设你本地的工作目录是在branches上(刚开发完branches上的一个版本,提交了代码),那么可以像下面这样做:
1
2
|
svn switch trunk-url-of-your-project
svn merge branch-url-of-your-project
|
其中,第一条命令是将本地工作目录切换到trunk上。执行完这条命令后,你本地的工作目录里的文件就会变成与trunk里的文件一致。
第二条命令是将branches上的文件合并到本地。执行完这条命令行,你本地的工作目录里的文件就会变成与branches合并的结果。但是请注意,由于本地的工作目录已经是trunk了(用svn info可查看),所以这一更新,就导致本地有若干文件变成“已修改,但未提交”的状态。因此,你需要把本地因merge被修改过的文件提交一次,就可以使得trunk上的文件变成与branches合并后的版本:
1
|
svn ci -m
"Merge branch to trunk"
|
文章来源:http://www.codelast.com/
关于svn merge的更详细说明,可参考此文档。
(8)为文件添加上可执行权限
假设你有一个脚本文件checkin到代码库中了,但是你在commit之前,却忘了给它添加可执行权限,那么,当checkout出来这份代码时,就会得到一个没有x权限的脚本,还需要手工再为它添加上x权限,非常麻烦。所以,要为该文件添加上x权限:
1
|
svn propset svn:executable on your-script.sh
|
然后再 svn ci 提交修改即可(尽管你没有修改文件内容,只是修改了文件的权限,也是会被标记为已修改的,需要将此修改提交到代码库中)。