- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在一个项目中工作,其中一个已发布版本处于维护阶段,两个或多个版本同时处于开发阶段。
这就是对主干的需要产生怀疑的地方。
我已经阅读了 The Read Bean and others(Pragmatic Version Control with Subversion)中的 SVN 书籍,然后所有人都建议使用以主干为中心的开发模式。我不知道在我的情况下这是否适用,以及是否存在其他具有多版本发布周期且成功使用其他模式的项目。
为什么推荐以主干为中心的模式?版本分支离主干越来越远有什么问题吗?我这个架构与主干的集成有什么意义吗?
/-----gamma-----/(3)----------> / / /----beta---/(1)---/(2)--/---beta--------/--\ / / / \ /------------alpha--/------/---\ \ / \ \------------trunk--------------------(a)----------------------(b)------------------>
编辑:
当我说两个或多个开发版本时,我指的是具有递增功能级别的软件版本。在上面的图形中:
意味着所有分支的功能都包含在以后的分支中(通过同步合并)。分支在稳定性级别(旧 分支更稳定)和功能(年轻 分支具有新功能)方面有所不同。
编辑 2,在 Trident 回答后:
稳定版本的开发是在一个主干的分支中完成的,然后在稳定时合并回主干,所以主干包含所有稳定的变化,最终是更稳定的软件版本。
我现在问这个问题是因为我正在重新考虑整个项目的分支策略。
最佳答案
我要把你的图表重新整理一下:
/-----gamma-----/(3)---------->
/ /
/----beta---/(1)---/(2)--/---beta--------/--\
/ / / \
/------------alpha--/------/---\ \
/ \ \
------------trunk--------------------(a)----------------------(b)------------------>
首先,删除 trunk
,因为您没有使用它。是的,您正在合并回主干,但您永远不会从中取出代码。相反,beta
来自 alpha
,gamma
来自 beta
。不妨省去将所有精力合并回您从未真正使用过的代码行:
/-----gamma-----/(3)---------->
/ /
/----beta---/(1)---/(2)--/---beta--------/
/ / /
/------------alpha--/------/
/
trunk
现在,让我们整理一下你的图表,让主要的发展线漂亮而笔直:
trunk-alpha-------beta-----------------------gamma-------------------------->
\ / / \ /
\---alpha-/------/ \---beta-------/
然后,终于把所有东西都翻过来了……
/-alpha-\-----\ /--beta-------\
/ \ \ / \
trunk------/--(beta)---\-----\--------/-(gamma)---------\------(gamma)-------->
你的后备箱来了!
我知道你在做什么。您没有在主干上编码,因为主干应该代表您的版本。在您的原始图中,主干上有两个版本。点 (a) 将分支 alpha 合并回主干,点 (b) 将分支 beta 合并回主干。这代表您的 Release alpha 和 Release beta。
但是,这就是标签的用途!您在发布上制作标签,您的标签现在代表您的发布。而且,它更好,因为标签保留了文件的历史记录。
假设您在 (b) 点前往您的后备箱并记录特定文件的日志。您在 (b) 点看到文件,在 (a) 点看到另一个版本。但是,您不知道该文件是如何在点 (a) 和点 (b) 之间更改的。事实上,你甚至不知道谁是对特定更改负责的发布版本。
但是,如果您对分支进行了标记,而不是将代码合并回主干,您会看到该文件的整个历史记录都回到了该文件的第一个版本。 Subversion 的日志命令(如果您不使用 --stop-on-copy
开关)会将您从标记带到分支 beta 并返回到主干。
啊,你说,但是我如何才能看到发布 alpha 和发布 beta 之间的区别?在我的方案中,我可以查看主干的历史!
但是,如果您需要查看一个版本与另一个版本之间的所有更改,您可以轻松地在两个标签之间进行比较。而且,因为它们是标签,所以找到实际的发布版本要容易得多,而不是试图找出主干上的哪个版本代表您的哪个版本。
所以,你确实有一个后备箱,但你只是不这么调用它。
关于svn - 多版本项目中是否需要主干,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8039294/
我正在使用 NetBeans 开发 Java 中的 WebService,并使用 gradle 作为依赖管理。 我找到了this article关于使用 gradle 开发 Web 项目。它使用 Gr
我正在将旧项目从 ant 迁移到 gradle(以使用其依赖项管理和构建功能),并且在生成 时遇到问题>eclipse 项目。今天的大问题是因为该项目有一些子项目被拆分成 war 和 jar 包部署到
我已经为这个错误苦苦挣扎了很长时间。如果有帮助的话,我会提供一些问题的快照。请指导我该怎么办????在我看来,它看起来一团糟。 *** glibc detected *** /home/shivam/
我在 Ubuntu 12.10 上运行 NetBeans 7.3。我正在学习 Java Web 开发类(class),因此我有一个名为 jsage8 的项目,其中包含我为该类(class)所做的工作。
我想知道 Codeplex、GitHub 等中是否有任何突出的项目是 C# 和 ASP.NET,甚至只是 C# API 与功能测试 (NUnit) 和模拟(RhinoMocks、NMock 等)。 重
我创建了一个 Maven 项目,包装类型为“jar”,名为“Y”我已经完成了“Maven 安装”,并且可以在我的本地存储库中找到它.. 然后,我创建了另一个项目,包装类型为“war”,称为“X”。在这
我一直在关注the instructions用于将 facebook SDK 集成到我的应用程序中。除了“helloFacebookSample”之外,我已经成功地编译并运行了所有给定的示例应用程序。
我想知道,为什么我们(Java 社区)需要 Apache Harmony 项目,而已经有了 OpenJDK 项目。两者不是都是在开源许可下发布的吗? 最佳答案 事实恰恰相反。 Harmony 的成立是
我正在尝试使用 Jsoup HTML Parser 从网站获取缩略图 URL我需要提取所有以 60x60.jpg(或 png)结尾的 URL(所有缩略图 URL 都以此 URL 结尾) 问题是我让它在
我无法构建 gradle 项目,即使我编辑 gradle 属性,我也会收到以下错误: Error:(22, 1) A problem occurred evaluating root project
我有这个代码: var NToDel:NSArray = [] var addInNToDelArray = "Test1 \ Test2" 如何在 NToDel:NSArray 中添加 addInN
如何在单击显示更多(按钮)后将主题列表限制为 5 个(项目)。 还有 3(项目),依此类推到列表末尾,然后它会显示显示更少(按钮)。 例如:在 Udemy 过滤器选项中,当您点击查看更多按钮时,它仅显
如何将现有的 Flutter 项目导入为 gradle 项目? “导入项目”向导要求 Gradle 主路径。 我有 gradle,安装在我的系统中。但是这里需要设置什么(哪条路径)。 这是我正在尝试的
我有一个关于 Bitbucket 的项目。只有源被提交。为了将项目检索到新机器上,我在 IntelliJ 中使用了 Version Control > Checkout from Ve
所以,我想更改我公司的一个项目,以使用一些与 IDE 无关的设置。我在使用 Tomcat 设置 Java 应用程序方面有非常少的经验(我几乎不记得它是如何工作的)。 因此,为了帮助制作独立于 IDE
我有 2 个独立的项目,一个在 Cocos2dx v3.6 中,一个在 Swift 中。我想从 Swift 项目开始游戏。我该怎么做? 我已经将整个 cocos2dx 项目复制到我的 Swift 项目
Cordova 绝对是新手。这些是我完成的步骤: checkout 现有项目 运行cordova build ios 以上生成此构建错误: (node:10242) UnhandledPromiseR
我正在使用 JQuery 隐藏/显示 li。我的要求是,当我点击任何 li 时,它应该显示但隐藏所有其他 li 项目。当我将鼠标悬停在文本上时 'show all list item but don
我想将我所有的java 项目(223 个项目)迁移到gradle 项目。我正在使用由 SpringSource STS 团队开发的 Gradle Eclipse 插件。 目前,我所有的 java 项目
我下载this Eclipse Luna ,对于 Java EE 开发人员,如描述中所见,它支持 Web 应用程序。我找不到 file -> new -> other -> web projects
我是一名优秀的程序员,十分优秀!