Linux下常用CVS命令

 1. 登錄 -- login


$ export CVSROOT=:pserver:username@cvs_server_ip:path_to_cvsroot

Note:
pserver是訪問方式,如果服務器設置的是口令認證,則是 pserver。
username是CVS服務器的用戶名,可以根據你的設置修改。

cvs_server_ip是CVS服務器的IP地址。
path_to_cvsroot是CVS服務器的CVSROOT目錄。

登陸CVS服務器: 
$ cvs login

這時候cvs會問你口令,請把你在CVS服務器上的口令敲進去:
Passwd: xxxxxxxx

2. 提交項目 -- import

cvs import [-options] repository vendortag releasetag...

Note: 
該命令將當前目錄下的所有文件(包括子目錄)導入源代碼儲存庫。
repository :項目名稱,在CVS服務器上會創建以這個名字命名的倉庫。
vendortag : 項目分支的總標記。(不常用)
releasetag :標識文件的輸入層次的標記。 (一般用start)
使用import提交項目的時候,CVS會要求對項目進行說明。在默認狀態下,CVS會彈出文本編輯器。用戶也可以用-m “log_message”來輸入說明信息。

例如:
$cvs import -m "upload the first time as new module" judecvs v_0_0_1 start

提示:import 一般在第一次導入module時使用。後期修改文件後可直接使用commit命令提交修改的文件。

3. 從CVS導出項目 -- checkout

cvs checkout [options] modules...

此命令將源代碼儲存庫中已有的項目導出到當前目錄。
modules :項目名稱

例如、從倉庫中檢索出judecvs項目的源文件:
$ cvs checkout judecvs 


4. CVS 主要命令 -- update

更新當前工作目錄中的文件

cvs update [-options] [files...]

此命令比較指定CVS源碼庫中的文件和當前目錄下的文件,如果CVS源碼庫中有更高版本的源文件,則更新當前目錄下的文件。此命令只有在checkout命令使用過後才能使用。

在執行update命令時,CVS並不是簡單的將新版本覆蓋當前文件,而是試圖將新版本所做的修改添加到當前文件中去。如果發生衝突,CVS會以字符串“<<<<<<”和“>>>>>>”來表示衝突發生。這時候你可以修改文件,重新提交。

提示:如果你已經做過一次checkout了,那麼不需要重新checkout,只需要進入cvstest項目的目錄,更新一把就行了: 

例如:
$ cd judecvs
$ cvs update

5. CVS 主要命令 -- status

如果你不想直接更新,只是想看看有沒有更新的東西,那麼:

$ cvs status 

會給每個文件有一份狀態報告,類似這樣: 
==================================================
File: client.c Status: Up-to-date 
Working revision: 1.1.1.1 'Some Date' 
Repository revision: 1.2 /home2/cvsroot/judecvs/client.c,v 

這裏最重要的就是 Status 欄,這裏總共可能有四種狀態: 
Up-to-date:表明你要到的文件是最新的. 
Locally Modified:表明你曾經修改過該文件,但還沒有提交,你的版本比倉庫裏的新. 
Needing Patch:表明有人已經修改過該文件並且已經提交了!你的版本比倉庫裏的舊. 
Needs Merge:表明你曾經修改國該文件,但是別人也修改了這個文件,而且還提交給倉庫了!


6. CVS 主要命令 -- commit

保存修改到CVS中

cvs commit [-lnR] [-m 'log_message' | -f file] [-r revision] [files...]
此命令將當前目錄下的源代碼與CVS中最新版本比較,並進行更新。
[-m ‘log_message‘ ] :輸入修改說明。
[-r revision] :指定版本。
[files...] :指定修改文件。

$ cvs commit -m "add XXX function" client.c 

系統會提示
CVS: ----------------------------------------------------------------------
CVS: Enter Log. Lines beginning with `CVS:' are removed automatically
CVS:
CVS: Committing in .
CVS:
CVS: Modified Files:
CVS: client.c
CVS: ----------------------------------------------------------------------

退出後,系統詢問是否continue,輸入c,則完成checkin 
Log message unchanged or not specified
a)bort, c)ontinue, e)dit, !)reuse this message unchanged for remaining dirs
Action: (continue) c
Checking in client.c;
/home2/cvsroot/judecvs/client.c,v <-- client.c
new revision: 1.2; previous revision: 1.1
done

如果CVS上文件已經有其他人更新,也就是我當前工作的不是最新版本,系統提示commit失敗,這時候需要先update,然後把整合文件再commit.
cvs server: Up-to-date check failed for `client.c'
cvs [server aborted]: correct above errors first!
cvs commit: saving log message in /tmp/cvsCEjA9N

提示:修改文件之前先update或者先查看文件狀態,確認當前工作版本是最新版本。

7. 添加文件到項目中 -- add 

cvs add [-k kflag] [-m 'message'] files...

此命令並不真正添加文件,只是將文件註冊到項目中,要真正添加文件,還要使用commit命令。

例如:
$ cvs add -m "test add" testadd.c

提示:
cvs server: scheduling file `testadd.c' for addition on branch `v_0_0_2'
cvs server: use 'cvs commit' to add this file permanently

$ cvs commit

同 commit 過程一樣,CVS將testadd.c添加到項目中

8. CVS 主要命令 -- remove

從項目中刪除文件

cvs remove [-k kflag] [-m 'message'] files...

和add命令一樣,此命令並不真正刪除文件,只是將文件從項目中取消,要真正刪除文件,還要使用commit命令。

e.g. 
$ rm testadd.c
$ cvs rm testadd.c


系統提示
cvs server: scheduling `testadd.c' for removal
cvs server: use 'cvs commit' to remove this file permanently

$ cvs commit testadd.c

此時,CVS纔將testadd.c從項目的最新版本中刪除,但是如果它有以前的版本,以前版本依然存在。
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章