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