<output id="qn6qe"></output>

    1. <output id="qn6qe"><tt id="qn6qe"></tt></output>
    2. <strike id="qn6qe"></strike>

      亚洲 日本 欧洲 欧美 视频,日韩中文字幕有码av,一本一道av中文字幕无码,国产线播放免费人成视频播放,人妻少妇偷人无码视频,日夜啪啪一区二区三区,国产尤物精品自在拍视频首页,久热这里只有精品12

      使用svn——項目的目錄布局

      Subversion有一個很標準的目錄結構,是這樣的。
      比如項目是proj,svn地址為svn://proj/,那么標準的svn布局是
      svn://proj/
      |
      +-trunk
      +-branches
      +-tags
      這是一個標準的布局,trunk為主開發目錄,branches為分支開發目錄,tags為tag存檔目錄(不允許修改)。但是具體這幾個目錄應該如何使用,svn并沒有明確的規范,更多的還是用戶自己的習慣。

      對于這幾個開發目錄,一般的使用方法有兩種。我更多的是從軟件產品的角度出發(比如freebsd),因為互聯網的開發模式是完全不一樣的。
      第一種方法,使用trunk作為主要的開發目錄。
      一般的,我們的所有的開發都是基于trunk進行開發,當一個版本/release開發告一段落(開發、測試、文檔、制作安裝程序、打包等)結束后,代碼 處于凍結狀態(人為規定,可以通過hook來進行管理)。此時應該基于當前凍結的代碼庫,打tag。當下一個版本/階段的開發任務開始,繼續在trunk 進行開發。
      此時,如果發現了上一個已發行版本(Released Version)有一些bug,或者一些很急迫的功能要求,而正在開發的版本(Developing Version)無法滿足時間要求,這時候就需要在上一個版本上進行修改了。應該基于發行版對應的tag,做相應的分支(branch)進行開發。
      例如,剛剛發布1.0,正在開發2.0,此時要在1.0的基礎上進行bug修正。
      按照時間的順序
      1. 1.0開發完畢,代碼凍結
      2. 基于已經凍結的trunk,為release1.0打tag
        此時的目錄結構為
        svn://proj/
                     +trunk/ (freeze)
                     +branches/
                     +tags/
                             +tag_release_1.0 (copy from trunk)
      3. 2.0開始開發,trunk此時為2.0的開發版
      4. 發現1.0有bug,需要修改,基于1.0的tag做branch
        此時的目錄結構為
        svn://proj/
                     +trunk/ ( dev 2.0 )
                     +branches/
                                   +dev_1.0_bugfix (copy from tag/release_1.0)
                     +tags/
                             +release_1.0 (copy from trunk)
      5. 在1.0 bugfix branch進行1.0 bugfix開發,在trunk進行2.0開發
      6. 在1.0 bugfix 完成之后,基于dev_1.0_bugfix的branch做release等
      7. 根據需要選擇性的把dev_1.0_bugfix這個分支merge回trunk(什么時候進行這步操作,要根據具體情況)
      這是一種很標準的開發模式,很多的公司都是采用這種模式進行開發的。trunk永遠是開發的主要目錄。

      第二種方法,在每一個release的branch中進行各自的開發,trunk只做發布使用。
      這種開發模式當中,trunk是不承擔具體開發任務的,一個版本/階段的開發任務在開始的時候,根據已經release的版本做新的開發分支,并且基于這個分支進行開發。還是舉上面的例子,這里面的時序關系是。
      1. 1.0開發,做dev1.0的branch
        此時的目錄結構
        svn://proj/
                     +trunk/ (不擔負開發任務 )
                     +branches/
                                   +dev_1.0 (copy from trunk)
                     +tags/
      2. 1.0開發完成,merge dev1.0到trunk
        此時的目錄結構
        svn://proj/
                     +trunk/ (merge from branch dev_1.0)
                     +branches/
                                   +dev_1.0 (開發任務結束,freeze)
                     +tags/
      3. 根據trunk做1.0的tag
        此時的目錄結構
        svn://proj/
                     +trunk/ (merge from branch dev_1.0)
                     +branches/
                                   +dev_1.0 (開發任務結束,freeze)
                     +tags/
                             +tag_release_1.0 (copy from trunk)
      4. 1.0開發,做dev2.0分支
        此時的目錄結構
        svn://proj/
                     +trunk/
                     +branches/
                                   +dev_1.0 (開發任務結束,freeze)
                                   +dev_2.0 (進行2.0開發)
                     +tags/
                             +tag_release_1.0 (copy from trunk)
      5. 1.0有bug,直接在dev1.0的分支上修復
        此時的目錄結構
        svn://proj/
                     +trunk/
                     +branches/
                                   +dev_1.0 (1.0bugfix)
                                   +dev_2.0 (進行2.0開發)
                     +tags/
                             +tag_release_1.0 (copy from trunk)
      6. 選擇性的進行代碼merge
      這其實是一種分散式的開發,當各個部分相對獨立一些(功能性的),可以開多個dev的分支進行開發,這樣各人/組都不會相互影響。比如dev_2.0_search和dev_2.0_cache等。但是這樣merge起來就是一個很痛苦的事情。

      這里要注意一下的,第六步進行選擇性的merge,是可以當2.0開發結束后一起把dev_1.0(bugfix用)和dev_2.0(新版本開發 用)merge回trunk。或者先把dev_1.0 merge到dev_2.0,進行測試等之后再merge回trunk。
      這兩種方法各有利弊,第一種方法是可以得到一個比較純的dev_2.0的開發分支,而第二種方法則更加的保險,因為要測試嘛。

      以上呢,就是我說的兩種開發模式了,具體哪種好,并沒有定論。這里大致的說一下各自的優缺點
      第一種開發模式(trunk進行主要開發,集中式):
      優點:管理簡單
      缺點:當開發的模塊比較多,開發人數/小團隊比較多的時候,很容易產生沖突而影響對方的開發。因為所有的改動都有可能觸碰對方的改動
      第二重開發模式(分支進行主要開發,分散式):
      優點:各自開發獨立,不容易相互影響。
      缺點:管理復雜,merge的時候很麻煩,容易死人。

      其實,這里并沒有一定之規,更多的時候是兩種模式結合使用。我個人來說是采用第一種方式為主,在某些情況下使用第二種方法。
      posted @ 2009-09-11 23:39  Rick Sun  閱讀(562)  評論(0)    收藏  舉報
      主站蜘蛛池模板: 国产成人永久免费av在线| 乱色熟女综合一区二区三区| 暖暖 免费 高清 日本 在线观看5 色老头亚洲成人免费影院 | 亚洲国产另类久久久精品| 久久久WWW成人免费精品| 兴业县| 九九热视频免费在线播放| 国产最大的福利精品自拍| 五月综合激情婷婷六月| 国产对白老熟女正在播放| 国产亚洲无线码一区二区| 亚洲成人av日韩在线| 安国市| 亚洲中文无码永久免费| 亚洲va成无码人在线观看天堂| 国产成人无码免费视频在线| 国产AV大陆精品一区二区三区| 午夜精品区| 国产一区二区三区av在线无码观看| 中文国产日韩欧美二视频| 亚洲人成网站77777在线观看| 激情综合网激情五月俺也去| 动漫AV纯肉无码AV电影网| 国产欧美综合在线观看第十页| 四虎影视www在线播放| 欧产日产国产精品精品| 国产成人精品无人区一区| 九九在线精品国产| 亚州少妇无套内射激情视频| 九九热免费在线播放视频| 日韩在线成年视频人网站观看| 亚洲中文字幕第一页在线| 国产又黄又爽又不遮挡视频| 免费人成视频x8x8国产| 少妇被粗大的猛烈进出69影院一| 九九热久久只有精品2| 熟妇女人妻丰满少妇中文字幕| 成人无码午夜在线观看| 日韩精品二区三区四区| 亚洲最大av资源站无码av网址| 亚洲精国产一区二区三区|