本節(jié)向大家簡單介紹一下一些常用的SVN目錄結(jié)構(gòu),在學(xué)習(xí)SVN的過程中,你可能會遇到SVN目錄結(jié)構(gòu)問題,在這里和大家共同學(xué)習(xí)一下,希望本文對你的學(xué)習(xí)有所幫助。
特殊目錄名說明
trunk主干,存儲最新穩(wěn)定版本
tag標記,主要保存比較完整理的版本標記,類似里程碑
tranch分支,用于分工操作.該目錄下又以各用戶名及日期為目錄進行存儲(推薦)
關(guān)于目錄(結(jié)構(gòu)舉例,相對規(guī)范)
/doc文檔的根目錄
/doc/trunk文檔的版本主干,存儲最新穩(wěn)定版本
/doc/trunk/...(內(nèi)容)
/doc/tag文檔的版本標志(類似里程碑)例如:doc_1_0/doc_1_1分別表是1.0本版與1.1版本
/doc/tag/doc_v_1_0/...(內(nèi)容)
/doc/tag/doc_v_1_1/...(內(nèi)容)
/doc/branch文檔的分支目錄(用戶分工)
/doc/branch/user1_070308文檔的分支目錄用戶(user1)于2007-03-08號加入分工
/doc/branch/user1_070308/...(內(nèi)容)
/doc/branch/user2_070101文檔的分支目錄用戶(user2)于2007-01-01號加入分工
/doc/branch/user2_070101/...(內(nèi)容)
/src源碼的根目錄
/src/trunk源碼的版本主干,存儲最新穩(wěn)定版本
/src/trunk/...(內(nèi)容)
/src/tag源碼的版本標志(類似里程碑)例如:doc_1_0/prj_src_1_1分別表是1.0本版與1.1版本
/src/tag/prj_src_v_1_0/...(內(nèi)容)
/src/tag/prj_src_v_1_1/...(內(nèi)容)
/src/branch源碼的分支目錄(用戶分工)
/src/branch/user1_070308源碼的分支目錄用戶(user1)于2007-03-08號加入分工
/src/branch/user1_070308/...(內(nèi)容)
/src/branch/user2_070101源碼的分支目錄用戶(user2)于2007-01-01號加入分工
/src/branch/user2_070101/...(內(nèi)容)
Subversion有一個很標準的SVN目錄結(jié)構(gòu),是這樣的。
比如項目是proj,svn地址為svn://proj/,那么標準的svn布局是
svn://proj/|
+-trunk
+-branches
+-tags
這是一個標準的布局,trunk為主開發(fā)目錄,branches為分支開發(fā)目錄,tags為tag存檔目錄(不允許修改)。但是具體這幾個目錄應(yīng)該如何使用,svn并沒有明確的規(guī)范,更多的還是用戶自己的習(xí)慣。
對于這幾個開發(fā)目錄,一般的使用方法有兩種。我更多的是從軟件產(chǎn)品的角度出發(fā)(比如freebsd),因為互聯(lián)網(wǎng)的開發(fā)模式是完全不一樣的。
第一種方法,使用trunk作為主要的開發(fā)目錄。
一般的,我們的所有的開發(fā)都是基于trunk進行開發(fā),當一個版本/release開發(fā)告一段落(開發(fā)、測試、文檔、制作安裝程序、打包等)結(jié)束后,代碼處于凍結(jié)狀態(tài)(人為規(guī)定,可以通過hook來進行管理)。此時應(yīng)該基于當前凍結(jié)的代碼庫,打tag。當下一個版本/階段的開發(fā)任務(wù)開始,繼續(xù)在trunk進行開發(fā)。
此時,如果發(fā)現(xiàn)了上一個已發(fā)行版本(ReleasedVersion)有一些bug,或者一些很急迫的功能要求,而正在開發(fā)的版本(DevelopingVersion)無法滿足時間要求,這時候就需要在上一個版本上進行修改了。應(yīng)該基于發(fā)行版對應(yīng)的tag,做相應(yīng)的分支(branch)進行開發(fā)。
例如,剛剛發(fā)布1.0,正在開發(fā)2.0,此時要在1.0的基礎(chǔ)上進行bug修正。
按照時間的順序
1.0開發(fā)完畢,代碼凍結(jié)
基于已經(jīng)凍結(jié)的trunk,為release1.0打tag
此時的SVN目錄結(jié)構(gòu)為
svn://proj/
+trunk/(freeze)
+branches/
+tags/
+tag_release_1.0 (copyfromtrunk)
2.0開始開發(fā),trunk此時為2.0的開發(fā)版
發(fā)現(xiàn)1.0有bug,需要修改,基于1.0的tag做branch
此時的SVN目錄結(jié)構(gòu)為
svn://proj/
+trunk/(dev2.0)
+branches/
+dev_1.0_bugfix(copyfromtag/release_1.0)
+tags/
+release_1.0 (copyfromtrunk)
在1.0bugfixbranch進行1.0bugfix開發(fā),在trunk進行2.0開發(fā)
在1.0bugfix完成之后,基于dev_1.0_bugfix的branch做release等
根據(jù)需要選擇性的把dev_1.0_bugfix這個分支merge回trunk(什么時候進行這步操作,要根據(jù)具體情況)
這是一種很標準的開發(fā)模式,很多的公司都是采用這種模式進行開發(fā)的。trunk永遠是開發(fā)的主要目錄。請期待下節(jié)關(guān)于SVN目錄結(jié)構(gòu)介紹。