一、從版本庫擷取資訊
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