我是一名新手程序员,对 GitHub 完全陌生。我正在与一位同事合作开展他多年来一直从事的项目。
至今:
他创建了一个存储库并加载了所有初始文件。我将它分叉到我的帐户中,以便我可以单独处理它。
现在:
如果他喜欢这些更改,我如何才能对我的存储库进行提交并与他共享,以便他可以检查更改并将它们合并到他的存储库中?
我知道 GitHub 上有很多信息,但我什至不知道从哪里开始。任何帮助是极大的赞赏。
我是一名新手程序员,对 GitHub 完全陌生。我正在与一位同事合作开展他多年来一直从事的项目。
至今:
他创建了一个存储库并加载了所有初始文件。我将它分叉到我的帐户中,以便我可以单独处理它。
现在:
如果他喜欢这些更改,我如何才能对我的存储库进行提交并与他共享,以便他可以检查更改并将它们合并到他的存储库中?
我知道 GitHub 上有很多信息,但我什至不知道从哪里开始。任何帮助是极大的赞赏。
有很多方法可以做到这一点,github 推荐拉取请求,除非您没有对存储库的推送访问权限,否则您将需要这样做或发送补丁。这里有一个这样的工作流程的例子
git clone git@github.com:<their repo> [optional folder name]
cd reponame (or optional folder name)
如果存储库有子模块,那么
git submodule update --init (if the repo has submodules)
git submodule foreach 'git checkout <their working branch>'
分叉代码。分叉您计划处理的特定存储库。这将为您提供您自己的项目副本。在您计划使用的存储库中设置 git。
cd <repo dir or optional one chosen)
git remote set-url origin git@github.com:<your github name>/<your repo>.git
git remote add --track next upstream git://github.com/<their github name>/<their repo>.git
那是您为帮助编写代码而设置的存储库。您可以执行 git pull、git push 等(这将来自/来自您的 fork)。要从合作伙伴 repo 的分支中提取更改,只需执行以下操作:
git pull upstream branch
您将无法 git push 到他们的仓库,因为您需要执行拉取请求。
当您满意时,请转到 github(您的项目)并选择 diff 和 pull request。这允许您输入一条消息,lib 维护者将收到一条消息来处理请求。它还将显示您的拉取请求是否会干净地合并,如果维护者必须修复代码,则不太可能被接受。