在介紹CVS命令之前,先說點別的
如以前說,倉庫內除樂源文件外,還包括一系列的管理文件.位於$CVSROOT/CVSROOT
修改管理文件的方法等同於源代碼文件,利用CVS命令提取和修改.
下面描述每個文件的用途:
checkoutlist 支持CVSROOT目錄的其它管理文件,允許為各種CVS命令定置信息
commitinfo 在cvs commit命令執行時,這個文件指定樂文件提交時執行的命令
cvswrappers 定義樂一個包裝程序當文件登記或檢取時就會執行.
editinfo 允許你在commit命令啟動前在日志信息被記錄後執行的腳本
history 跟蹤所有影響倉庫的命令
loginfo 類似coimmitinfo, 只是在文件提交後執行
modules 允許為一組文件定義一個符號,否則必須為每一個要引用的文件
指定部分路徑名(相對於$CVSROOT)
nitify 控制從/"watch/"來的通知./"watch/"由/"cvs watch add/"和/"cvs edit/"
設置
rcsinfo 為commit log回話指定一個模板.
taginfo 定義樂在任意/"tag/"操作後執行的程序.
CVS服務器的安裝
默認情況下,CVS在Redhat Linux中已經安裝,這一點可以通過在Linux命令行的情況下運行:
代碼如下:
rpm –q cvs
如果出現CVS的版本信息就證明已經安裝成功了。
CVS服務器安裝包可以從網上的很多地方下載,也可以到CVS的官方網站進行下載。根據你所使用的系統,下載相應的版本,然後進行安裝。因為我們的項目是在Redhat Linux下使用CVS服務器進行版本管理,所以本文將主要基於Redhat Linux進行介紹。首先下載CVS服務器的rpm包,當然也可以下載其它方式的包如源程序包,然後采用以下命令進行安裝:
代碼如下:
rpm -ivh cvs-1.11.7-1.i386.rpm
CVS服務器的配置
安裝完之後的第一件事就是要配置CVS服務器的配置文件,使其能正常的工作。首先在/etc/services文件中添加cvspserver,使其成為Linux的一種服務也就是cvs服務器例程的入口,配置如下:
cvspserver 2401/tcp # cvs client/server operations
cvspserver 2401/udp # cvs client/server operations
如果文件中已經存在上面的兩行文字,就不用添加了。
配置xinetd,用xinetd來啟動CVS驗證服務器:
進入到/etc/xinetd.d/目錄,然後編輯一個文本文件,名字一定要與/etc/services中的入口名字cvspserver一致,所以這裡用cvspserver作為文件名,文件的內容如下所示:
代碼如下:
service cvspserver
{
disable = no
flags = REUSE
socket_type = stream
wait = no
user = root
server = /usr/bin/cvs
server_args = -f --allow-root=/usr/cvsroot pserver
log_on_failure += USERID
}
編輯文件之後測試cvspserver服務是否配置成功。
執行
代碼如下:
/etc/init.d/xinetd restart
重新啟動服務,啟動成功之後,執行下面的語句,驗證服務是否啟動正常:
代碼如下:
telnet localhost 2401
如果出現如下字樣:
Trying 127.0.0.1...
Connected to localhost.
Escape character is '^]'.
輸入hi,會繼續輸出如下字樣
cvs [pserver aborted]: bad auth protocol start: hi
Connection closed by foreign host.
出現以上的現象表示CVS用戶驗證服務器已經配置成功。
如果出現如下字樣,表示配置不成功,請重新檢查以上的配置:
Trying 127.0.0.1...
telnet: connect to address 127.0.0.1: Connection refused
CVS的環境變量
CVS使用樂幾個環境變量
CVSROOT 倉庫根目錄的完整路徑名
CVSREAD 如果設置,表明在checkout操作時所有的文件都置成只讀
CVSBIN CVS利用樂很多RCS的命令,指定樂RCS工具的路徑
CVSEDITOR 指定用戶書寫日志信息所使用的編輯器
CVS_RSH 啟動一個遠程CVS服務器時,所使用的shell的名稱
CVS_SERVER 決定/"cvs server/"的名字,缺省是CVS
CVSWRAPPERS cvswrapper腳本, 用來指定包裝文件名.
關鍵字
管理源文件的一種技術叫/"關鍵字替換/".在每次執行/"cvs commit/"操作後
源文件的某些關鍵字會被替換為可用的詞
$AUTHOR$ 用戶名
$Data$ 登記時的時間
$Header$ 標准的首部,包含RCS的完整路徑名,日期,作者
$Id$ 除RCS文件名不完整外與$Header$同.
$Log$ 包含RCS的完整路徑名,版本號,日期,作者和在提交時提供的日志信息.
$RCSfile$ 包含RCS的文件名,不包括路徑名
$Revision$ 分配的版本號
$Source$ RCS文件的完整名
$State$ 分配的版本的狀態,由 cvs admin -s 分配.
例:
在cvs commit之前,main.c裡有
static char *rcsid=/"$Id$/";
執行cvs commit後
main.c的改行變為:
static char *rcsid=/"$Id: main.c,v 1.2 1999/04/29 15:10:14 trimblef Exp$/";
下面開始說說CVS的命令
我們已下面倉庫的數據為例
$CVSROOT
--CVSROOT
--project
--src
--main
--main.c
--main.h
--print.c
--print.h
--term
--term.c
--term.h
CVS checkout 命令
從倉庫提取指定的文件到當前目錄,並建立同樣的結構,並創建CVS目錄
例
代碼如下:
bash$ cvs checkout project
bash$ cvs checkout project/src/main
為使用便利,我們可以對一個目錄建一個縮寫,方法是修改$CVSROOT/CVSROOT/下的
modules文件.(當然是用cvs 命令完成)
代碼如下:
cvs checkout CVSROOT/modules
cd CVSROOT
vi modules
我們在文件尾加上
代碼如下:
src project/src
print project/src/print
cvs commit
以後我們就可以用cvs checkout print來代替
cvs checkout project/src/print
cvs checkout命令缺省是得到最新版本.我們也可以得到某一個老版本
代碼如下:
cvs checkout -r 1.1 print
將print的1.1版的代碼取出.
cvs checkout的詳細用法見cvs -H checkout的輸出.
CVS commit 命令
在對文件的修改完成後,用cvs commit提交到倉庫.
代碼如下:
cvs commit -m /"Update by xxxxx/" project
cvs commit -m /"Update main.c/" main.c
提交完成後,當前的版本號會更新,如原來為1.1,現為1.2. 這兩個版本都在
倉庫的主干(maintrunk)上.
-m選項可以記錄有關提交的注釋.如果沒有指定-m選項,在環境變量CVSEDITOR
中指定的編輯器被調用(vi是缺省的),提示鍵入文本,修改記錄注釋.
CVS update
CVS允許多人同時對一個文件進行修改.
假設泥正在修改文件的一部分,現想合並更新自己的本地拷貝(checkout)和
另一個人所做的修改(已經放在倉庫裡),可用cvs update
代碼如下:
cvs update
CVS tag , CVS rtag
創建分支可以使用戶對一些文件進行修改而不會影響主干(當commit時).
創建分支首先為擬修改的某些文件創建一個標簽(tag),標簽是賦於一個文件或一組文件的符號.在源代碼的生命周期裡,組成一組模塊的文件被賦於相同的標簽.
創建標簽:在工作目錄裡執行cvs tag
例: 為src創建標簽:
代碼如下:
cvs checkout src
cvs tag release-1-0
標簽創建後, 就可以為其創建一個分支:
代碼如下:
cvs rtag -b -r release-1-0 release-1-0-path print
-b :創建分支
-r release-1-0 :指定存在的標簽
releas-1-0-patch:分支
print: 模塊名
合並
使用cvs update -j 選項可以將分支上的改變與本地文件拷貝合並.
代碼如下:
cvs update -j release-1-0 print.c
cvs release
對源文件作必要修改後, 可以用cvs release 刪除本地工作拷貝
並通知其他開發者這個模塊不再使用.
代碼如下:
cvs release -d print
-d : 刪除
print: 目錄
沖突
由於CVS允許多人同時修改同一文件,沖突是不可避免的.例如當兩人
同時修改同一文件的同一行時.
這時,如用cvs update 更新,CVS檢測到沖突的存在,它會將沖突的代碼
用/"<<<<<<<<<<<<<<>>>>>>>>>>>>>>/"標識.這時需手工處理這段代碼.與引起
沖突的開發者協商,並對文件修改後即可用cvs commit提交.