歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
Linux教程網 >> Linux綜合 >> Linux命令 >> linux操作系統上cvs常用命令

linux操作系統上cvs常用命令

日期:2017/2/28 10:03:09   编辑:Linux命令
Linux命令

登陸cvs: cvs -d :pserver:[email protected]:/home/cvsroot login 將提示你輸入密碼,登陸成功後以後在登陸不需要密碼

檢出整個工程(必須先檢出整個工程,才能進行其它的操作) cvs -d :pserver:[email protected]:/home/cvsroot checkout mindquiz 在執行update時可以轉到本地相應目錄直接 cvs update 也可以在其它目錄cvs update 目錄名

(下面是網絡上找到)

1.登陸cvs: cvs -d :pserver:[email protected]:/home/cvsroot login

Note:pserver是訪問方式,如果服務器設置的是口令認證,則是 pserver。 username是 CVS服務器的用戶名,可以根據你的設置修改; the_server_name是CVS服務器的名稱或者IP地址; /home/cvsroot是你的CVS服務器的CVSROOT目錄,根據你的CVS服務器設置做修改或者詢問管理員.

這時候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從項目的最新版本中刪除,但是如果它有以前的版本,以前版本依然存在。

cvs update的信息報告 "cvs update" 後在信息框裡會列出你的操作,你的文件update的情況,這裡是CVS使用的所有其它單字符信息性消息的列表: U [path] 在本地機更新get到了服務器上最新的或者最新版本的文件。 P [path] 像“U”一樣,只是在update時你的網絡帶寬少的情況下CVS服務器所出現的提示。 M [path] 這意味著您已經修改過該文件了;而且,有可能資源庫中新的更改已成功地合並到該文件。 C [path] 錯誤警報,"C" 字符表明該文件存在沖突,需要在使用 "commit" 提交前解決這沖突。 A [path] 該文件是計劃要添加的,即添加了但尚未提交,這時你還使用update命令,CVS就會有這個提示,當你 "commit" 時,它被正式添加

到服務器庫中,問題解決。 R [path] 象 "A" 一樣,"R" 讓您知道該文件計劃要刪除的,即刪除了但尚未提交,這時你還使用update命令, CVS就會有這個提示,當你 "

commit" 後,該文件就會從服務器庫中刪除,問題解決。

Copyright © Linux教程網 All Rights Reserved