cvs 命令收集

2021-09-08 15:21:23 字數 3762 閱讀 9952

常用的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...