我有一个项目托管在GitHub有人已经分叉。在他们的fork上,他们创建了一个新的分支“foo”并做了一些更改。我如何拉他们的“foo”到一个新的分支也命名为“foo”在我的回购?
我知道他们可以向我提交撤诉请求,但我想自己启动这个程序。
假设:
因为他们分叉了我的项目,所以我们的回购都有相同的“历史”
虽然GitHub显示他们的项目是从我的分叉,我的本地存储库没有任何引用到这个人的项目。我需要添加他们的遥控器吗?
我还没有一个叫“foo”的分支-我不知道我是否需要手动创建这个。
我绝对想把它拉到一个单独的分支,而不是我的主人。
如果fork repo是受保护的,所以你不能直接推入它,并且你的目标是对它们的foo进行更改,那么你需要像这样将它们的分支foo放入你的repo:
git remote add protected_repo https://github.com/theirusername/their_repo.git
git fetch protected_repo
git checkout --no-track protected_repo/foo
现在你有了一个foo的本地副本,没有与它相关联的上游。你可以向它提交更改(或不提交更改),然后将你的foo推到你自己的远程repo。
git push --set-upstream origin foo
现在foo在你的GitHub回购和你的本地foo正在跟踪它。如果他们继续对foo进行更改,你可以获取他们的并合并到你的foo中。
git checkout foo
git fetch protected_repo
git merge protected_repo/foo