linux++切换分支,repo sync 时自动切换当前分支的remote track分支的问题

当使用reposync时,如果本地分支dev与远程track分支origin/dev不一致,且manifest.xml指定track分支为origin/master,reposync会自动将dev的track切换到master并尝试rebase。这可能导致意外的分支修改,提示信息可能被忽略。要避免这种情况,可以采取相应措施。
摘要由CSDN通过智能技术生成

使用repo sync时,如果当前仓库有检出本地分支,假设为dev, 对应的远程track分支为origin/dev。 而manifest.xml中指定的track分支为origin/master,那么在repo sync时会自动将当前的dev分支的远程track分支修改为origin/master, 不仅如此,同时还会将origin/master上的修改rebase到本地的这个dev分支上。

projectA/: manifest switched refs/heads/dev...master

project projectA/

First, rewinding head to replay your work on top of it...

Applying: y

虽然repo会给出上面的提示信息" manifest switched",但经常会被接下来的输出淹没掉,而且很多时候这样的行为都不是我们想要的,要想终止这个行为,可以这样修改

diff --git a/project.py b/project.py

index 22e4a5d..3ce6500 100644

--- a/project.py

+++ b/project.py

@@ -1169,6 +1169,8 @@ class Project(object):

syncbuf.info(self,

'manifest no longer tracks %s',

branch.merge)

+      syncbuf.fail(self, "branch is not consistent:%s, %s" %(branch.merge, self.revisionExpr))

+      return

if cnt_mine < len(local_changes):

# Upstream rebased.  Not everything in HEAD

that's all

Git 的详细介绍:请点这里

Git 的下载地址:请点这里

0b1331709591d260c1c78e86d0c51c18.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值