- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我们有一个存储库,其中包含许多由 Maven 构建的 Java 项目(约 20 个)。
我们的存储库中有 3 个分支,patch
、minor
和 major
。
对于ProjectA
,patch
分支上的pom.xml
和MANIFEST.MF
设置为1.3.7
,而在 minor
上,它们被设置为 1.4.0
,在 major
上,它们被设置到 2.0.0
。
这是痛点:从 patch
分支执行发布时,然后我们想要 merge 那个新标签(projecta-1.3.7
) 转发到 minor
和 major
分支。
问题是,即使我们只更改了补丁分支上的一个 .java
文件(假设这是一个关键错误修复),每次我们都有遍历并解决每个 pom.xml
和 MANIFEST.MF
文件的冲突。所以这个:
git checkout minor
git merge projecta-1.3.7
导致 minor
获得错误修复(呜呜呜!)但随后还需要我们检查并比较所有 projecta-1.3 之间的冲突。 7
项目使用补丁版本,minor
项目使用次要版本。
有没有办法告诉 Git,作为 merge 命令的一部分,我们要对 pom.xml、MANIFEST.MF
使用“我们的”策略>,但是否应使用默认策略解决任何其他冲突?
最佳答案
我通常通过将 bug 修复的代码更改作为单独的提交提交来处理这个问题,以提高版本号(我假设是对 pom.xml 和 MANIFEST 文件的更改)。然后我可以将代码更改提交正常 merge 到其他分支,然后最后“伪造” merge “version #bump”更改分别与 merge --strategy=ours
。
操作请求:
Our process is: (1) release project 1.3.7 (2) merge the tag into future branches ('minor') (3) update POM/MANIFEST to 1.3.8, (4) ...work... (5) then, a couple weeks later, start back at (1) again.
好的,我的流程有点不同,但按照您的流程,如果第 3 步生成提交 #1234ABCD,那么我会额外执行第 3a 步:
$ git checkout MAINLINE
$ git merge --strategy=ours 1234ABCD
这将确保当您返回并在将来点击第 2 步时,#bump 版本将被视为已 merge 并被忽略。
或者,稍后再执行 3a。当您将来到达第 2 步时,然后执行#1234ABCD 的伪 merge ,然后 merge #1234ABCD 之后分支上的所有提交。当您再次在分支中修改版本号时 - “假 merge ”它(立即或稍后)。
核心思想只是将提交与版本# 的颠簸隔离开来,然后“伪造”将其单独 merge ——何时执行取决于您。即使版本 # bump 位于要 merge 的分支上的提交中间,然后 merge 所有其他提交之前的第一个提交,然后假 merge 那个颠簸版本 # 的提交,然后 merge 所有提交在那之后。
这是我上周进行的 merge 的粗略图片。左边距下方的提交是 MAINLINE 开发,不在左边距的是在 RELEASEBRANCH(维护分支)中进行的。提交顺序与您的流程不匹配,但这并不重要。
* bc26f91 Oct 31 Fake merge from IT17p2 to ignore inapplicable commit: All web-apps: blah blah blah (MAINLINE)
|\
| * 3cd69ad Oct 31 All web-apps: bump release # for new release (RELEASEBRANCH)
* | 8eae339 Oct 31 Merge fix from IT17p2: All web-apps: blah blah blah
|\ \
| |/
| * 3612072 Oct 31 All web-apps: blah blah blah
| |
关于Git merge 策略将 'patch'分支整合到 'minor', 'minor'分支整合到 'major',我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19794135/
前言 这个东西有啥用,好玩? 确实, 好玩归好玩,其实很有使用场景。 可以自己选则一些业务节点触发这个机器人助手的消息推送; 简单举例: 有人给你的系统留下反馈意见了,推送到运营群去; 2.项目部署成
1. JWT 简介 JSON Web Token(JWT) 是一个开放标准(RFC 7519),它定义了一种紧凑的、自包含的方式,用于作为 JSON 对象在各方之间安全地传输信息。该信息可以被验证和信
我的页面上有多个 ajax 调用,我想将它们合并为一个函数。 目前我在几个地方都有这种类型的功能: function AjaxCallOne () { //do something $.ajax(
我的 Facebook 集成基本上可以在我的应用程序中运行:出现 Facebook 对话框,用户可以选择“允许”或“不允许”。但是,我不明白 API 是如何工作的!我有一个使用此代码的 Activit
我必须将文件夹结构从我的应用程序共享到 OneDrive。 我已经检查了一个驱动器的 sdk,但在那个 sdk 中只能共享文件而不是文件夹,并且没有在该 sdk 中创建文件夹的选项 https://g
我是支付网关集成方面的新手。我必须在我的项目 (CORE PHP) 中集成 CCAvenue 支付网关集成。但是我不知道如何为开发人员测试创建商户帐户,如何获取商户 key 等。我已经进行了研发,但是
我正在尝试将“社交选项”集成到我的应用程序中。 我有 iOS6,但我的想法是有一个适用于 iOS5 的应用程序。使用 Twitter 框架非常简单,并且可以在 r.0 版本和 6.0 版本的设备上运行
我正在尝试将 flurryAds 集成到我的 iPhone 应用程序中,但我无法做到这一点。我导入名为 的 .h 文件 #import "Flurry.h" #import "FlurryAds.h"
我正在尝试在我的网站中实现类似 facebook 的按钮和评论,但我在 IE7 中遇到了评论框问题。 COMMENT USING 下拉框不知何故没有显示其他可用选项。这是我用来实现它的代码片段:
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 11 年前。 Improve th
我正在使用 SOAP API 进行 PayPal 集成(Express Checkout)。在 DoExpressCheckout 调用后,我调用 GetExpressCheckoutDetails。
我正在尝试将 paypal 作为支付网关之一集成到我的应用程序中,但在我点击支付按钮后它会返回以下错误。 错误 java.lang.RuntimeException:无法使用 Intent { cmp
我目前正在尝试将 paypal 结账与我们的在线商店集成。我们正在针对 Sandbox 进行测试。除了 IPN(即时付款通知)之外的所有内容都有效。 我们阅读了很多有关 Paypal 更改其安全模型的
我正在开发一个 android 应用程序,我想在其中集成 facebook 之类的。我正在浏览链接 http://developers.facebook.com/docs/guides/mobile/
所以我正在尝试构建一个集成了 FitBit 的 iOS 应用程序 (Swift 2)。 一旦用户打开“步行”页面,用户应该能够看到他每天的步数。 理想情况下,我们不希望每个用户都注册到 FitBit。
我是集成投递箱的新手,但我不太确定如何生成调用以获取请求 token secret 。 https://www.dropbox.com/developers/reference/api#request
我已经成功集成了 PayPal。一切正常。但我希望我的表格在成功付款后重定向到我的网站。另一个问题:如何从 PayPal 得到回应?这是我的 Paypal 表格。谢谢。 `
我在我的 Android 应用程序中集成了 Paypal 。我有一个主要 Activity - 和关于 Activity ,我在其中显示 Paypal 按钮。关于从主 Activity 访问的 Act
前言: 小编引入的图片和文字描述都是来自于尚硅谷的视频讲解,在此感谢尚硅谷的老师,同时也结合 seata文档官方文档进行整合 项目地址(gitee): https://gitee.com/qine
目录 1. demo project 1.1 接口准备 1.2 配置准备 2. docker 开启远程连接
我是一名优秀的程序员,十分优秀!