CVS的常用命令
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||
svn常用命令 E:/svn/Repository 這個目錄是你要建版本庫的那個目錄。 注意要加引號。這樣你的版本庫就會成爲一個windows 服務。 刪除服務 啓動服務 停止服務 ============================================================================================================================= 注意:以下$不在要輸入到命令行內。 $ svn help $ svn help add
(1) 導入項目 $ cd ~/project$ mkdir -p svntest/{trunk,branches,tags}$ svn import svntest https://localhost/test/svntest --message "Start project"...$ rm -rf svntest (2) 導出項目 $ svn checkout https://localhost/test/svntest/trunk $ svn diff --revision PREV:COMMITTED foo.c# shows the last change committed to foo.c$ svn log --revision HEAD# shows log message for the latest repository commit$ svn diff --revision HEAD# compares your working file (with local changes) to the latest version# in the repository$ svn diff --revision BASE:HEAD foo.c# compares your “pristine” foo.c (no local changes) with the # latest version in the repository$ svn log --revision BASE:HEAD# shows all commit logs since you last updated$ svn update --revision PREV foo.c# rewinds the last change on foo.c# (foo.c's working revision is decreased)$ svn checkout --revision 3# specified with revision number$ svn checkout --revision {2002-02-17}$ svn checkout --revision {15:30}$ svn checkout --revision {15:30:00.200000}$ svn checkout --revision {"2002-02-17 15:30"}$ svn checkout --revision {"2002-02-17 15:30 +0230"}$ svn checkout --revision {2002-02-17T15:30}$ svn checkout --revision {2002-02-17T15:30Z}$ svn checkout --revision {2002-02-17T15:30-04:00}$ svn checkout --revision {20020217T1530}$ svn checkout --revision {20020217T1530Z}$ svn checkout --revision {20020217T1530-0500} $ svn update$ svn add foo.file$ svn add foo1.dir$ svn add foo2.dir --non-recursive$ svn delete README$ svn copy foo bar$ svn move foo1 bar1$ svn status$ svn status --verbose$ svn status --verbose --show-updates$ svn status stuff/fox.c$ svn diff$ svn diff > patchfile$ svn revert README$ svn revert $ ls -lsandwich.txtsandwich.txt.minesandwich.txt.r1sandwich.txt.r2 $ svn resolved sandwich.txt $ cp sandwich.txt.r2 sandwich.txt$ svn resolved sandwich.txt $ svn revert sandwich.txtReverted 'sandwich.txt'$ ls sandwich.*sandwich.txt $ svn commit --message "Correct some fatal problems"$ svn commit --file logmsg$ svn commit $ svn log$ svn log --revision 5:19$ svn log foo.c$ svn log -r 8 -v$ svn diff$ svn diff --revision 3 rules.txt $ svn diff --revision 2:3 rules.txt $ svn diff --revision 4:5 http://svn.red-bean.com/repos/example/trunk/text/rules.txt$ svn cat --revision 2 rules.txt $ svn cat --revision 2 rules.txt > rules.txt.v2$ svn list http://svn.collab.net/repos/svn$ svn list --verbose http://svn.collab.net/repos/svn$ svn checkout --revision 1729 # Checks out a new working copy at r1729…$ svn update --revision 1729 # Updates an existing working copy to r1729… svn cleanup (6) 分支和合並 建立分支方法一:先checkout然後做拷貝,最後提交拷貝。 $ svn checkout http://svn.example.com/repos/calc bigwcA bigwc/trunk/A bigwc/trunk/MakefileA bigwc/trunk/integer.cA bigwc/trunk/button.cA bigwc/branches/Checked out revision 340.$ cd bigwc$ svn copy trunk branches/my-calc-branch$ svn statusA + branches/my-calc-branch$ svn commit -m "Creating a private branch of /calc/trunk."Adding branches/my-calc-branchCommitted revision 341. $ svn copy http://svn.example.com/repos/calc/trunk / http://svn.example.com/repos/calc/branches/my-calc-branch / -m "Creating a private branch of /calc/trunk."Committed revision 341. $ svn checkout http://svn.example.com/repos/calc/branches/my-calc-branch $ cd calc$ svn info | grep URLURL: http://svn.example.com/repos/calc/trunk$ svn switch http://svn.example.com/repos/calc/branches/my-calc-branchU integer.cU button.cU MakefileUpdated to revision 341.$ svn info | grep URLURL: http://svn.example.com/repos/calc/branches/my-calc-branch $ svn diff -r 343:344 http://svn.example.com/repos/calc/trunk$ svn merge -r 343:344 http://svn.example.com/repos/calc/trunk$ svn commit -m "integer.c: ported r344 (spelling fixes) from trunk."$ svn merge -r 343:344 http://svn.example.com/repos/calc/trunk my-calc-branch$ svn merge http://svn.example.com/repos/branch1@150 / http://svn.example.com/repos/branch2@212 / my-working-copy$ svn merge -r 100:200 http://svn.example.com/repos/trunk my-working-copy$ svn merge -r 100:200 http://svn.example.com/repos/trunk$ svn merge --dry-run -r 343:344 http://svn.example.com/repos/calc/trunk 建立標籤和建立分支沒什麼區別,不過是拷貝到不同的目錄而已。 $ svn copy http://svn.example.com/repos/calc/trunk / http://svn.example.com/repos/calc/tags/release-1.0 / -m "Tagging the 1.0 release of the 'calc' project."$ lsmy-working-copy/$ svn copy my-working-copy http://svn.example.com/repos/calc/tags/mytagCommitted revision 352. 此外,你還可以刪除某個分支。 $ svn delete http://svn.example.com/repos/calc/branches/my-calc-branch / -m "Removing obsolete branch of calc project." (7) 版本庫管理 $ svnadmin help...$ svnadmin help create...$ svnadmin create --fs-type bdb /usr/local/repository/svn/test$ chown -R svn.svn /usr/local/repository/svn/test (8) 查詢版本庫信息 $ svnlook help...$ svnlook help tree...$ svnlook tree /usr/local/repository/svn/test --show-ids 使用說明 二
轉載說明 此轉載基於原作者最後更新於2002-06-15 23:18:05的版本。原作可以在這裏找到,本文的版權歸原作者所有。本文作者原爲網易公司的資深開發人員。 版權聲明 可以任意轉載,轉載時請務必標明原始出處和作者信息 概述:CVS是一個C/S系統,多個開發人員通過一箇中心版本控制系統來記錄文件版本,從而達到保證文件同步的目的。 CVS服務器(文件版本庫) 以下是本文主要內容:開發人員可以主要挑選2, 6看就可以了,CVS的管理員則更需要懂的更多一些
一個系統20%的功能往往能夠滿足80%的需求,CVS也不例外,以下是CVS最常用的功能,可能用到的還不到它全部命令選項的10%,更多的功能請在實際應用過程中體會,學習過程中應該是用多少,學多少,用到了再學也不遲。 CVS環境初始化 環境設置:指定CVS庫的路徑CVSROOT
後面還提到遠程CVS服務器的設置:
初始化:中心庫版本庫的初始化,其實就是一個目錄
項目首次導入
項目導出:將代碼從CVS庫裏導出
CVS的日常使用 確認修改:確認自己的修改並寫入到CVS庫裏
注意:CVS的很多動作都是通過cvs commit進行最後確認並修改的,在確認的前,還需要用戶填寫修改註釋,以幫助其他開發人員瞭解修改的原因。如果不用寫-m "comments"而直接確認`cvs commit file_name` 的話,cvs會自動調用系統缺省的文字編輯器(一般是vi)要求你寫入註釋。 同步最近修改:開始工作前和將自己的工作導入到CVS庫裏前都要做一次:先同步 後修改
注意:不要使用項目首次導出後,以後就要用cvs update在導出的項目目錄下進行同步了,而不是每次重新cvs checkout來同步文件了。如果導出後修改了文件,然後再次從導出的項目目錄的上一級cvs checkout proj等於是刪除了proj目錄然後重新導出,上次導出後的修改就全丟了。 修改某個版本註釋:每次只確認一個文件到CVS庫裏是一個很好的習慣,但難免有時候忘了指定文件名,把多個文件以同樣註釋commit到CVS庫裏了,以下命令可以允許你修改某個文件某個版本的註釋:
刪除文件:
以上面前2步合併的方法爲:
注意:很多cvs命令都有縮寫形式:commit=>ci; update=>up; checkout=>co; remove=>rm; 添加文件 文件添加後,比如:
添加目錄:
查看修改歷史:
查看當前文件不同版本的區別
查看當前文件(可能已經修改了)和庫中相應文件的區別
cvs的web界面提供了更方便的定位文件修改和比較版本區別的方法,具體安裝設置請看後面的cvsweb使用 正確的通過CVS恢復舊版本的方法:
這個命令是給file.name加一個STICK TAG: "1.2" ,雖然你的本意只是想將它恢復到1.2版本
如果不小心已經加成STICK TAG的話:用cvs update -A 解決 移動文件:文件重命名 刪除,移動目錄: CVS Branch:項目多分支同步開發 確認版本里程碑:多個文件各自版本號不一樣,項目到一定階段,可以給所有文件統一指定一個階段里程碑版本號,方便以後按照這個階段里程碑版本號導出項目,同時也是項目的多個分支開發的基礎。
開始一個新的里程碑:
標記所有文件開始進入2.x的開發 注意:CVS裏的revsion和軟件包的發佈版本可以沒有直接的關係。但所有文件使用和發佈版本一致的版本號比較有助於維護。 在開發項目的2.x版本的時候發現1.x有問題,但2.x又不敢用,則從先前標記的里程碑:release_1_0導出一個分支release_1_0_patch
一些人先在另外一個目錄下導出release_1_0_patch這個分支:解決1.0中的緊急問題,
而其他人員仍舊在項目的主幹分支2.x上開發 在release_1_0_patch上修正錯誤後,標記一個1.0的錯誤修正版本號
如果2.0認爲這些錯誤修改在2.0裏也需要,也可以在2.0的開發目錄下合併release_1_0_patch_1中的修改到當前代碼中:
CVS的遠程認證:通過SSH遠程訪問CVS 使用cvs本身的遠程認證很麻煩,需要定義服務器和用戶組,用戶名,設置密碼等,而且不安全,因此和系統本地帳號認證並通過SSH傳輸是比較好的辦法,通過在客戶機的/etc/profile裏設置一下內容:
所有客戶機所有本地用戶都可以映射到CVS服務器相應同名帳號了。 如果CVS所在服務器的SSH端口不在缺省的22,或者和客戶端與CVS服務器端SSH缺省端口不一致,有時候設置了: :ext:[email protected]#port:/path/to/cvsroot 仍然不行,比如有以下錯誤信息:
解決的方法是做一個腳本指定端口轉向(不能使用alias,會出找不到文件錯誤):
然後:chmod +x /usr/bin/ssh_cvs 注意:port是指相應服務器SSH的端口,不是cvs pserver的端口 CVSWEB:提高程序員比較文件修改效率 CVSWEB就是CVS的WEB界面,可以大大提高程序員定位修改的效率: CVSWEB的下載:CVSWEB從最初的版本已經演化出很多功能界面更豐富的版本,這個是個人感覺覺得安裝設置比較方便的:http://www.spaghetti-code.de/software/linux/cvsweb/ 下載解包:
把配置文件cvsweb.conf放到安全的地方(比如和apache的配置放在同一個目錄下),
轉到/path/to/apache/conf下並修改cvsweb.conf:
CVSWEB可不能隨便開放給所有用戶,因此需要使用WEB用戶認證:
修改httpd.conf: 增加
CVS TAGS: who? when? 將$Id$ 加在程序文件開頭的註釋裏是一個很好的習慣,cvs能夠自動更新其中的內容成:file_name version time user_name 的格式,比如:cvs_card.txt,v 1.1 2002/04/05 04:24:12 chedong Exp,可以這些信息瞭解文件的最後修改人和修改時間 幾個常用的缺省文件:
Default.java: 注意文件頭一般註釋用 /* 開始 JAVADOC註釋用 /** 開始的區別
default.pl:
相關資源: CVS HOME: CVS FAQ: 相關網站: CVS 免費書: CVS 命令的速查卡片:
|
CVS的常用命令
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.