目錄
一、從版本庫獲取信息... 1
二、從版本庫到本地... 2
三、從本地到版本庫... 2
四、高級應用... 4
一、從版本庫獲取信息
svn help command
獲取子命令說明
svn info $URL
查看工作空間信息
若是目錄地址,查看本地目錄信息,若無$DIR,默認爲當前目錄
若是文件地址,查看本地文件信息
svn list
顯示給定目錄在某一版本存在的文件
svnlist 顯示當前目錄下svn記錄文件列表,不訪問版本庫
svn list $URL 不下載到本地查看目錄中的文件
檢查歷史:
svn log
查看歷史修改信息,展示每個版本附加在版本上的作者和日期信息和所有路徑修改
svn log 5:19 查看版本5到19的歷史信息
svn log 查看當前目錄的歷史修改信息
svn log filename 查看單個文件的歷史修改信息
svn log $URL 查看$URL的歷史信息
svn diff
查看所做的修改,即展示每一個文件改變的詳細情況
svn diff 比較本地工作拷貝的修改
svn diff -r 3 filename 比較本地工作拷貝與版本庫指定版本
svn diff -r 2:3 $URL比較版本庫的兩個版本
本地(工作拷貝)和本地修改前版本比較,精確查看修改內容,刪除的行前一個-,添加的行前一個+
svn cat
在屏幕打印某個文件特定版本內容
svn cat -r 2 filename 顯示文件指定版本內容
svn st [參數] 【st=status】
執行檢查
【與svn diff 不同在於svn st只顯示文件修改情況,而非詳細內容】
svn st $DIR 查看本地已做的修改
在做svn revert/ci之前,請執行此操作,以免誤操作
輸出提示: M A D R ? C *
修改 增加 刪除 提花 未納入版本控制 衝突 文件比版本庫版本舊
參數 |
例子 |
意義 |
是否聯繫版本庫 |
path |
svn status |
查看當前目錄下所有目錄文件信息 |
否,與本地修改前比對 |
|
svn status aa/a.txt |
查看指定目錄下文件信息 |
|
-v |
svn status -v |
當前目錄下所有目錄文件信息,即使未改變過 |
同上
|
-u |
svn status -u |
與版本庫最新版本比較,*提示文件需要更新 |
是,與版本庫最新版本比較
|
二、從版本庫到本地
svn co $URL $DIR 【co=checkout】
將SVN庫文件檢出到本地工作空間
將目標文件檢出到本地目錄下,簡歷一個工作拷貝,每個目錄都包含一個.svn管理目錄
$URL與$DIR同級
若是不加本地目錄地址,默認將遠程文件夾整個拷到當前目錄下
svn export $URL $DIR 【一般在打包時候使用】
從版本庫導出一個乾淨的目錄樹,與svn co同,但不含.svn目錄
非工作拷貝
svn up 【up=update】
更新本地工作空間,與SVN服務器保持同步
更新自己的工作拷貝,得到這對按時間他人的修改
輸出提示: U A D R G C
更新 增加 刪除 替換 合併 衝突
svn up 更新本地工作空間,默認將當前目錄及其子目錄下所有文件都更新到最新版本
svn up filename 更新filename爲最新
svn up –r 200 file.c –m “update the version to 200”將本地的file.c還原爲200版本,並提交到服務器【本地是拿下來了,版本庫端並沒有被變】
三、從本地到版本庫
svn import $DIR $URL -m "註釋信息"【產生提交操作】
將$DIR下的目錄導入到$URL下面去,而不會在$URL下新建目錄
即,將DIR下的內容拷貝到URL下
例如:有一個文件夾test/code.java
svn import test $URL/test –m “import a new file”將code.java拷到版本庫test文件夾下
此時本地的DIR無變化,本地與服務器並未建立管理,需要執行checkout取出服務器內容後才真正在本地建立了工作拷貝
相當於從本地拷貝到版本庫,源文件與版本庫文件無關
若想新建目錄 svn import $DIR $URL/$DIR
svn add file 【本地操作】
往本地添加文件或者目錄,svn ci時才進行提交
svn add test test.c 添加test目錄及test.c文件
svn delete file
從本地工作或者URL裏面刪除目錄,或移除文件
svn del test test.c 本地工作空間刪除test目錄和test.c ,執行svn ci時候才提交,版本增加【一旦svndel,本地文件夾或文件就被刪除了】
svn del $URL –m “Del the dir for some reason” 產生提交,版本增加
svn mv $URL/old $URL/new -m "註釋" 【mv=move 等價於svn cp 後svn delete】
移動或拷貝工作空間或者版本庫的文件/目錄 也可用於文件改名
svn mv foo.cf.c 工作空間文件改名,使用svn ci 則產生提交
svn mv –m “Move a file” $URL1 $URL2 移動文件,產生提交
svn rm $URL/dir -m "註釋"
目錄刪除
svn ci -m "註釋信息" 【ci=commit】
提交增刪改操作
注意,提交之後,本地的svn list依舊是舊的,需要手動svn up獲取最新的
svn revert filename【本地操作,會丟失修改,慎用】
恢復對文件或者目錄的修改,用於未執行提交操作(ci)之前,撤銷本地修改。
等價於執行svn rm filename,svn up -r BASE filename
svn revert –R $DIR 恢復工作空間$DIR目錄下的所有修改
svn revert test.c 恢復test.c的修改
svn mkdir $URL/dir -m "註釋"
工作空間或者版本庫創建目錄
svn mkdirnewdir 本地工作空間新建目錄newdir,通過svn ci後產生提交
svn mkdir –m “Making a dir”$URL/$NEW_DIR 產生提交
svn cp $URL1 $URL2 -m "註釋"
工作拷貝或者版本庫之間文件的相互拷貝
起源(SRC) 和 目的(DST) 可以是工作拷貝路徑或地址(URL):
工作拷貝 -> 工作拷貝 : 複製和通過調度進行增加(包含歷史)
工作拷貝 -> 地址(URL) : 馬上提交一個工作拷貝到地址(URL)
地址(URL) ->工作拷貝 : 簽出地址(URL)到工作目錄,通過調度進
行增加
地址(URL) ->地址(URL) : 完全服務器端複製;一般用於分支和標籤
svn cp foo.txtbar.txt 本地文件拷貝
svn cp $URL$DIR 本地新增$URL目錄,會把$URL目錄放到$DIR下
svn cp $URL1$URL2 –m “註釋” 產生提交操作
svn cp $DIR$URL –m “註釋” 產生提交操作
也可用於建立新的分支
之後 svn co$URL2,就可以在分支工作拷貝中進行操作,svn ci -m "fix bug 1031"
找回刪除的項目
當前版本中無,上一版本中存在
-精確拷貝svn cp -r19 $URL/filename filename
-檢查結果 svnstatus
-提交 svn ci -m "resurrected c.txt fromr19"
四、高級應用:
svn merge –r m:n path
比較兩個版本樹,將區別應用到本地拷貝 初始版本樹 最終版本樹 一個接收區別的工作拷貝
合併分支
-找到分支產生的版本
svn log -v --stop-on-copy $URL 查到分支產生的版本是r10
-使工作目錄爲主幹的本地拷貝
$cd proj/trunk
$svn up
可以看到最新版本,假設r15
-執行合併
$svn merge -r 10:15 $URL
-檢查合併結果,也許要手工解決衝突,最後提交
$svn ci -m "merged br_1_0 10:15 to trunk"
代碼回滾
撤銷一個已提交的版本,修改有誤,不應該提交,需要回滾到上一個版本
-執行命令
$svn merge -r 20:19 $URL
-檢查工作拷貝結果
$svn status
-提交拷貝結果
$svn ci -m "undo change commited in r20"
svn switch $URL
提供一種改變工作拷貝的快捷方式
比如原拷貝在trunk上,目前想切換到分支上工作
$svn switch $分支URL
運行svn info |grep URL 可看到檔籤的url是分支的路徑
svn resolved filename
刪除衝突標記,在svn up是,提示U(本地文件被更新)G(成功合併)沒有必要處理
C本地和服務器修改衝突,需手工處理
當發生衝突 -C標記文件
-衝突文件中植入衝突標記(<<... == ... >>)
-每一個衝突的文件,SVN在本地工作拷貝中生成三個未版本化的文件、
filename.mine本地修改後的版本
filename.rOLDREV上次更新後未作修改的本本
filename.rNEWREV服務器最新版本
此時執行svn ci失敗
應 -手工解決衝突,打開衝突文件,根據衝突標記(<<...==...>>)修改文件,可參考三個未版本化文件,修改完成後刪除這些標記
-運行svn resolved filename 或手工刪除三個未版本化的文件
-運行svn ci -m "註釋" 提交修改
svn lock -m “LockMessage” [-force] PATH
加鎖, 鎖定版本庫的工作拷貝路徑或URL,所以沒有其他用戶可以提交這些文件的修改。
改變工作拷貝,版本庫【訪問版本庫了】
svn lock –m “lock test file” test.php
svn unlock PATH
解鎖
轉載自:http://blog.csdn.net/wklken/article/details/6594956