Android SVN开发实战的文件夹结构呈现

svn有一个非常标准的文件夹结构,这是。

例如,该项目是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.0开发完成,代码 冻结

基于已经冻结的trunk,为release1.0打tag

此时的文件夹结构为

svn://proj/
+trunk/ (freeze)
+branches/
+tags/
    +tag_release_1.0 (copy from trunk)

2.0 開始开发。trunk此时为2.0的开发版

发现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)

在1.0 bugfix branch进行1.0 bugfix开发,在trunk进行2.0开发

在1.0 bugfix 完毕之后,基于dev_1.0_bugfix的branch做release等

依据须要选择性的把 dev_1.0_bugfix这个分支merge回trunk(什么时候进行这步操作,要依据详细情况)

这是一种非常标准的开发模 式。非常多的公司都是採用这样的模式进行开发的。trunk永远是开发的主要文件夹。

另外一种方法

在每个release的branch中进行 各自的开发。trunk仅仅做公布使用。

这样的开发模式其中,trunk是不承担详细开发任务的,一个版本号/阶段的开发任务在開始的时候。依据已经 release的版本号做新的开发分支,而且基于这个分支进行开发。还是举上面的样例,这里面的时序关系是。

1.0开发,做 dev1.0的branch

此时的文件夹结构

svn://proj/
+trunk/ (不担负开发任务 )
+branches/
    +dev_1.0 (copy from trunk)
+tags/

1.0开发完毕,merge dev1.0到trunk

此时的目 录结构

svn://proj/
+trunk/ (merge from branch dev_1.0)
+branches/
     +dev_1.0 (开发任务结束。freeze)
+tags/

依据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)

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)

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)

选择性的进行代码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进行主要开发。集中式):

长处:管理简单

缺点:当开发的模块比較多,开发人数/小团队比較多 的时候。非常easy产生冲突而影响对方的开发。由于全部的修改都有可能触碰对方的修改。

另外一种开发模式(分支进行主要开发,分散式):

长处:每 自独立的发展,不easy相互作用。

缺点:管理复杂,merge很麻烦的时间,easy死。

其实,而不是明显的在这里。许多其它时间两种 模式组合。

时间: 2024-10-01 01:13:21

Android SVN开发实战的文件夹结构呈现的相关文章

Android SVN开发实战之目录结构介绍

svn有一个很标准的目录结构,是这样的.比如项目是proj,svn地址为svn://proj/,那么标准的svn布局是 svn://proj/ | +-trunk +-branches +-tags 这 是一个标准的布局,trunk为主开发目录,branches为分支开发目录,tags为tag存档目录(不允许修改).但是具体这几个目录应该如何使 用,svn并没有明确的规范,更多的还是用户自己的习惯. 对于这几个开发目录,一般的使用方法有两种.我更多的是从软件产品的角度出发 (比如freebsd)

Cocos2d-x旧引擎文件夹结构

转自:http://blog.csdn.net/lwuit/article/details/7870395 Cocos2d-x的文件夹结构例如以下: 文件夹的详细结构介绍例如以下: Box2D:物理引擎Box2D的相关源文件 Chipmunk:物理引擎chipmunk的相关源文件 cocos2dx:cocos2d-x引擎的核心部分.存放了引擎的大部分源文件 CocosDenshion:声音模块相关源文件 Debug.win32:在Windows 上调试输出文件夹 Doxygen:生成doxyge

AndroidStudio文件夹结构视图讲解

近期,Google已经打算废弃Eclipse.而要大力支持他的亲生儿子AndroidStudio了,已经不在维护Eclipse了,也就是说在Eclipse上面出了什么问题.Google已经不在会管了,可是Google为了维护之前那些eclipse的铁杆粉丝,从Studio1.2版本号之后就支持能够直接把咱们eclipse项目导到Studio里面直接使用了,不用再从eclipse里面export啊,这个那个费事劲,Studio会自己主动将eclipse转换成Studio认识的东西,至于怎么转的,这

《Android Studio开发实战 从零基础到App上线》资源下载和内容勘误

http://blog.csdn.net/aqi00/article/details/72907534 http://blog.csdn.net/aqi00/article/details/73065392 版权声明:本文为博主原创文章,未经博主允许不得转载. 目录(?)[+] 资源下载 下面是<Android Studio开发实战 从零基础到App上线>一书用到的工具和代码资源:1.本书使用的Android Studio版本为2.2.3,因为Android官网现在不提供该版本的下载,所以博主

使用gridlayout布局后,因某些原因又删除,并整理文件夹结构时,Unable to resolve target &amp;#39;android-7&amp;#39;

出现的问题 [2013-01-11 10:52:39 - gridlayout_v7] Unable to resolve target 'android-7' 事由:在一次做九宫格时.误使用了gridlayout布局.因此eclipse为我自己主动下载了??gridlayout_v7_2 文件,并放到工作空间文件夹. 由于不再须要,也为了文件夹结构的清晰性,须要将其删除.但在关闭(Close Project)这个文件时,eclipse自己主动编译项目出错,提示?Unable to resolv

android NDK开发编译C++文件出现Type &#39;jint&#39; could not be resolved和Unresolved inclusion: &lt;jni.h&gt;的解决办法

今天在编译android NDK工程的时候,在jni文件夹下的cpp文件中报了一大堆错误,诸如:Unresolved inclusion: <jni.h>.Type 'jint' could not be resolved.Type 'jintArray' could not be resolved等,根据经验,这样的错误肯定是没有包含相应的头文件导致的. 解决方案: 选中工程,右键->Properties,点击C/C++ General展开,点击Path and Symbols,在右边

开源分享二(Android相机开发实战)

开源分享二(Android相机开发实战) 开源分享 一(StickerCamera + 仿微信多图选择) 前言 上篇博文给大家分享了两个非常实用的项目功能模块,不知道大伙感觉如何?有木有一种臭袜子味扑鼻,酸爽的赶脚!!!贱笑贱笑了~ ~ OK!不扯淡了,言归正传.本文将主要为大家介绍Android中自定义相机的开发,做Android应用的童鞋应该都知道,在应用中使用相机功能有两种方式: 调用Camera API 自定义相机 调用系统相机 由于需求不同,所以选择的方案固然也不同,至于第二种调用系统

Android中项目中各个文件夹的含义和用途详解

1.src:存放所有的*.java源程序. 2.gen:为ADT插件自动生成的代码文件保存路径,里面的R.java将保存所有的资源ID. 3.assets:可以存放项目一些较大的资源文件,例如:图片.音乐.字体等. 4.res:可以存放项目中所有的资源文件,例如:图片(*.png.*.jpg).文本等. 5.res/drawable-hdpi:保存高分辨率图片资源,可以使用Resources.getDrawable(id)可以获得资源类型. 6.res/drawable-ldpi:保存低分辩率图

JBoss AS 7之文件夹结构(The Return Of The King)

1.2 JBoss As 7体系结构 以下介绍一下JBoss的体系结构,详细的文件夹结构. 假设熟悉曾经JBoss版本号的人,一定会发现JBoss AS 7与之前的JBoss的文件夹结构有了非常大的不同.以下介绍一下JBoss AS 7的文件夹结构.                                         主文件夹结构 文件夹 描写叙述 bin Unix和win环境下的启动脚本和启动配置文件 bundles 存放OSGI bundle docs/schema 存放XML