常用的cvs命令
. 匯入乙個源**庫:
源**庫在目錄/home/weiqiong/project,其下有檔案test.c和test.h
shell>cd /home/weiqiong/project
shell>cvs import -m "test project" test(需要匯入的專案名) weiqiong(開發商資訊) start(版本資訊)
2. 獲得第乙份工作copy
shell>cd /home/weiqiong
shell>cvs checkout test
則目錄/home/weiqiong/test中就會有test.c和test.h兩個檔案
3. 檢查工作拷貝(-q為去除無關的提示文字)
shell>cvs -q diff -c(比較cvs上和本地的**的不同)
如果希望檢視某一特定檔案的變化,在最後加上檔名
4. 瀏覽記錄資訊
shell>cvs log test.c
5. 檢視兩個版本的不同之處:
shell>cvs diff -c -r 1.3 -r 1.4 test.c
6. 恢復舊版本:如果當前最新版本為1.4,而你想將其恢復到1.3版本,重新建立乙個新版本1.5
shell>cvs -q update -p -r 1.3 hello.c > hello.c
(如果沒有-p,表示檢驗出1.3版本,但是會sticky;加上-p,將1.3版本打到標準輸出中,且沒有sticky,此處覆蓋hello.c檔案)
shell>cvs update hello.c
(可選,但是一般ci之前都要update一次)
shell>cvs ci -m "reverted to 1.3 code" hello.c
或者shell>cvs update -j 1.4 -j 1.3 hello.c
(將1.4->1.3的差異,應用到當前版本上)
shell>cvs update hello.c
(可選,但是一般ci之前都要update一次)
shell>cvs ci -m "reverted to 1.3 code" hello.c
如果是目錄
在你需要恢復的目錄下
cvs tag tag_r1_0_0_2
cvs update -j tag_r1_0_0_2 -j tag_r1_0_0_1
cvs update
cvs ci -m "restore to r1_0_0_1"
或者在你需要恢復的目錄的上一級目錄中
cvs export -d project_name.old -r tag_r1_0_0_1 project_name
cp -rf project_name.old/* project_name/
rm -rf project_name.old
cvs update
cvs ci -m "restore to r1_0_0_1"
請注意,內容是恢復到了tag_r1_0_0_1,但是版本一直在增加。
7. 增加檔案
vi newfile
cvs add newfile(若為二進位制檔案則用cvs add -kb readme.doc)
cvs ci -m "add newfile" newfile
8. 刪除檔案
rm newfile.c
cvs remove newfile.c
cvs ci -m "removed newfile.c" newfile.c
9. 增加目錄
mkdir newdir
cvs add newdir
10. 要增加帶有多級目錄和檔案的子目錄,方法是匯入乙個目錄
比如原專案叫abc,在abc目錄下想增加乙個帶有多級目錄和檔案的目錄jni,
cd jni
cvs import -m "new dir jni" abc/jni weiqiongimport r1_0_0_0
然後,客戶端(自己和其他人的客戶端)需要
cvs update -d 獲取最新的目錄更新
11. 刪除目錄
先刪除目錄下的所有檔案,然後
cvs update -p 從工作copy中刪除空目錄,但是源**庫依然保留著空目錄
如果需要更新工作copy的目錄與源**庫完全一致(主要是包括空目錄),需要
cvs update -d
如果不需要恢復,應該
到伺服器上rm -rf刪除該目錄
在客戶端,rm -rf刪除該目錄,然後在該目錄的同級cvs目錄下,修改entries檔案,刪除帶有該目錄名的一行
12. 匯出不帶cvs目錄的原始檔,export只能針對乙個tag或者日期匯出,空目錄不會被匯出:
cvs export -r release1 project_name
cvs export -d 20021023 project_name
cvs export -d now project_name
cvs export和cvs co module的區別在於export不生成cvs目錄,也不匯出空目錄,用於作發布
13. 確認版本里程碑
cvs tag release_1_0
14. 開始乙個新的里程碑,標記所有檔案開始進入2.x的開發
cvs commit -m "make all release 2.0" -r 2.0
cvs up -a
15. 版本分支的建立
在開發專案的2.x版本的時候發現1.x有問題,但2.x又不敢用,
則從先前標記的里程碑:release_1_0匯出乙個分支release_1_0patch
cvs rtag -b -r release_1_0 release_1_0patch projname
一些人先在另外乙個目錄下匯出release_1_0patch這個分支:解決1.0中的緊急問題,
cvs checkout -r release_1_0patch
而其他人員仍舊在專案的主幹分支2.x上開發
在release_1_0patch上修正錯誤後,標記乙個1.0的錯誤修正版本號
cvs tag release_1_0patch_1
如果2.0認為這些錯誤修改在2.0裡也需要,也可以在2.0的開發目錄下合併release_1_0patch_1
中的修改到當前**中:
cvs update -j release_1_0patch_1
(將release_1_0patch->update -j release_1_0patch_1的改變,merge到當前的版本中)
16.修改某個版本注釋:
每次只確認乙個檔案到cvs庫里是乙個很好的習慣,但難免有時候忘了指定檔名,
把多個檔案以同樣注釋commit到cvs庫里了,以下命令可以允許你修改某個檔案某個版本的注釋:
cvs admin -m 1.3:"write some comments here" file_name
修改從1.2->1.3checkin時的注釋
17.在注釋中可以加入以下巨集,cvs會自動將其替換為相應的項
$id$ $header$ $author$ $date$ $revision$ $log$ $source$ $name$
18.檢視當前各檔案的狀態,包括檔案的當前編輯版本號,源**庫版本號,檔案的狀態
cvs status filename
19.粘著選項
cvs update -d "1999-04-09"
刪除粘著,回到當前最新版本
cvs update -a
收集CVS資源
cvs 是 concurrent versions system 的簡稱。它是現今 open source 成功發展的幕後功臣之一。cvs 解決多人合作開發時程式版本控管的問題,通常會再搭配郵件列表 mailing list 做為開發團隊溝通的管道。這種組合,使開發團隊不受時間地域限制,合作夥伴分散...
cvs命令總結
我們的開發小組使用cvs作為配置管理工具,在linux下沒有合手的cvs客戶端,只有使用命令列了 下面是常用命令,從csdn某位老兄的blog上拷貝過來的。環境變數的設定 export cvsroot pserver username 192.168.0.2 cvsrep 重要的命令 比較cvs上最...
CVS新增使用者的命令
1.在windows xp 上安裝cvs 伺服器端,cvsnt 2.在命令列視窗中首先登入cvs 命令如下 cvs d pserver administrator 127.0.0.1 mycvs login 注 這裡要用自己作業系統的管理員使用者代替administrator 3 新增使用者 cvs...