Chinaunix
标题:
svn 在linux下的使用实例
[打印本页]
作者:
Mozer
时间:
2008-12-17 13:36
标题:
svn 在linux下的使用实例
☆出现字符集转换错误
svn: Can
't convert string from native encoding to 'UTF-8':
这个错误信息通常会发生在Subversion客户端从版本库接收到一个UTF-8串,但字符不能转化为当前的地区文字时。例如,如果你的本地化设置是en_US,但是一个写作者使用日本文件名提交,你会在svn update接受文件时会看到这个错误。
解决方案
是设置你的本地化(例如:LANG=zh_CN.GBK),或者是修改版本库的文件名或信息。
☆将文件checkout到本地目录
svn checkout
path(path是服务器上的目录)
例如:svn checkout svn://192.168.168.168/pro/domain/
☆往版本库中添加新的文件
svn
add
file
例如:svn add woxingwosu.java(添加woxingwosu.java)
svn add *.java(添加当前目录下所有的java文件)
☆更新文件
svn commit
-m "LogMessage" [-N] [--no-unlock] PATH
(如果选择了保持锁,就使用--no-unlock开关)
例如:svn commit -m "woxingwosu" woxingwosu.java
☆加锁/解锁
svn lock
-m "LockMessage" [--force] PATH
例如:svn lock -m "woxingwosu" woxingwosu.java
svn unlock
PATH
☆查看文件或者目录状态
1)
svn status
path
(目录下的文件和子目录的状态,正常状态不显示)
【?:不在svn的控制中;M:内容被修改;C:发生冲突;A:预定加入到版本库;K:被锁定】
2)
svn status -v
path
(显示文件和子目录状态)
第一列保持相同,第二列显示工作版本号,第三和第四列显示最后一次修改的版本号和修改人。
注:svn status、svn diff和 svn revert这三条命令在没有网络的情况下也可以执行的,原因是svn在本地的.svn中保留了本地版本的原始拷贝。
☆查看日志
svn log
path
例如:svn log woxingwosu.java
☆删除文件
svn delete
path -m "message"
例如:svn delete svn://192.168.168.168/pro/domain/woxingwosu.java -m "woxingwosu"
☆比较差异
svn diff
path(将修改的文件与基础版本比较)
例如:svn diff woxingwosu.java
svn diff
-r m:n path(对版本m和版本n比较差异)
☆查看基础详细信息
svn info
path
例如:svn info woxingwosu.java
☆更新到某个版本
svn update -r
m path
例如:svn update -r 200 woxingwosu.java(将版本库中的文件woxingwosu.java还原到版本200)
svn update woxingwosu.java(更新,于版本库同步。如果在提交的时候提示过期的话,是因为
冲突,需要先update,修改文件
,然后清除
svn resolved
,最后再提交commit)
☆将两个版本之间的差异合并到当前文件
svn merge -r
m:n path
例如:svn merge -r 200:210 woxingwosu.java(将版本200与210之间的差异合并到当前文件,但是一般都会产生冲突,需要处理一下)
本文来自ChinaUnix博客,如果查看原文请点:
http://blog.chinaunix.net/u/31547/showart_1724948.html
欢迎光临 Chinaunix (http://bbs.chinaunix.net/)
Powered by Discuz! X3.2