让我们假设在GitHub上有一个存储库someone/foobar,我把它分叉到me/foobar。

我如何从父库直接将新提交拉到我的fork,而不需要添加一个单独的远程并记得定期从那里拉?

目标是:

Git从父存储库中获取 Git推送把所有东西都送到我的叉子上


当前回答

另一种选择是使用GitHub for Mac(我假设GitHub for Windows)中的upstreamRepoName/master按钮的更新。

其他回答

“拉”应用程序是一个自动设置和忘记解决方案。它会将fork的默认分支与上游存储库同步。

访问URL,点击绿色的“安装”按钮,选择你想要启用自动同步的存储库。

分支直接在GitHub上每小时更新一次,在你的本地机器上,你需要拉主分支以确保你的本地副本是同步的。

也在https://stackoverflow.com/a/58965171/946850回答。

访问https://github.com/me/foobar/compare/master...someone:master(当然,用相应的repo和用户名替换me, someone和foobar) 如果你看到绿色文本能够合并,然后按创建拉请求 在下一页上,滚动到页面底部并单击“合并拉取请求”和“确认合并”。

git remote set-url origin git@github.com:someone/foobar
git remote set-url origin --push git@github.com:me/foobar

但有一个警告: 如果你是唯一一个对你的fork进行更改的人,这是完美的。 然而,如果它是与其他人共享的,你可能不得不从你的分叉,在这种情况下,一个单独的遥控器是唯一的解决方案。

编辑: 实际上,您可以git调用git@github.com:me/foobar,这样就消除了警告。 哪一个更容易记住,由你来选择。

另一种选择是使用GitHub for Mac(我假设GitHub for Windows)中的upstreamRepoName/master按钮的更新。

最近(2021年5月初),GitHub网站为此提供了一个一键式按钮:

我无法抗拒点击它的诱惑。

关于这项新功能,请参阅GitHub的官方推文。