gpt4 book ai didi

android - 在 Android Repo 项目中切换 Git 分支

转载 作者:塔克拉玛干 更新时间:2023-11-02 20:05:10 25 4
gpt4 key购买 nike

我有一个关于使用 repo 切换分支的问题.我知道我可以像这样检查一个分支:

$ repo init ... -b foo
$ repo sync

我的理解是,这将 check out list 存储库的 foo 分支,然后 check out list 中描述的 git 项目。

我也明白我可以这样切换分支:

$ repo init ... -b bar
$ repo sync -d

我的问题是,我是否可以在每次不执行 repo init & repo sync 的情况下切换分支,这样做有什么影响?

举个例子:

$ repo init ... -b foo
$ repo sync -d
$ repo start foo-mytopic proj1 proj2
... make some commits ...
$ repo upload -t
$ repo init ... -b bar
$ repo sync -d
$ repo start bar-topic proj1 proj3
$ repo upload -t
$ cd proj1
$ git checkout foo-mytopic # IS THIS ALLOWED?

我以前试过这个,它似乎有效,但有点奇怪,因为我现在已经检查了 foo list 中的代码,但我当前的 list 分支是 酒吧。位于与 list 中描述的分支不同的分支上有什么影响?

注意:我读过this ,我认为我的问题是不同的。我知道如何切换分支。我对处于与当前 list 中描述的分支不同的分支的影响以及这可能如何影响我的工作流程感兴趣。

最佳答案

由于没有其他人能够回答这个问题,我做了更多的研究和实验。这是我的发现:

Tl;dr - 某些命令会做一些奇怪的事情。使用时要小心 repo syncrepo start .尝试坚持使用简单的 git 命令。 repo upload应该可以。

repo documentation说 repo 同步相当于

$ git fetch origin
$ git rebase origin/<BRANCH>

其中 BRANCH 是本地项目目录中当前 checkout 的分支。但是,根据我自己的经验,repo 还会根据其中的内容弄乱该分支的上游跟踪信息当前 list 。

继续上面的例子,git checkout foo-mytopic事实上,是允许的,并且会适本地表现。 repo 上传会将更改推送到 foo-mytopic 的分支正在跟踪(foo),但 repo 同步会更改上游跟踪信息。在这种情况下,手动运行可能更好 git fetch origingit rebase origin/<BRANCH> .

repo init 描述的 list (和分支)将不会再次发挥作用,直到 repo syncrepo start正在运行。

关于android - 在 Android Repo 项目中切换 Git 分支,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30759708/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com