为开源项目做贡献的10个步骤
创建干净,为开管理良好的源项GitHub贡献的简短指南。
在本文中,贡献我将给出10个简单的步骤步骤,以确保GitHub的为开贡献快速而干净。
目录:
贡献的源项生命周期(步骤) 1.fork主仓库 2.Fork后的仓库克隆到你的电脑 3.创建功能/特性分支 4.将更改提交到特性分支 5.将特性分支推到你fork的仓库 6.针对主仓库提出Pull Request(PR) 7.处理评论并合并PR 8.将主存储库作为上游添加到克隆仓库中 9.从上游更新你的master分支 10.将主分支push到你的fork仓库 (可选)删除特性分支 最后贡献的生命周期(步骤)
1.fork主仓库
fork主仓库会在你的帐户中创建一个副本。你可以进行更改并将任何代码推送到此fork,贡献而不必担心会弄乱原始代码库。步骤单击页面顶部的为开fork按钮以创建一个新的fork。
Fork后的源项版本库现在可以在你的账户中的“Repositories”部分找到。
2.Fork后的贡献仓库克隆到你的电脑
Fork后的仓库克隆到电脑上,这样我们就有了代码的步骤本地副本。单击Fork后的云南idc服务商为开仓库的SSH或HTTPS URL旁边的剪贴板图标来复制它。
现在在你的源项电脑上打开一个终端,然后运行以下命令来克隆fork的贡献仓库:
git clone git@github.com:theawesomenayak/guava.git3.创建功能/特性分支
在对代码进行任何修改时,最好的做法是为我们需要进行的修改创建一个新的特性分支。这样可以确保我们保持master分支的整洁,并且能够在必要时简单地还原我们的代码或进行更新。
切换到克隆分支仓库后创建的目录:
cd guava创建一个新特性分支,其名称可以标识你计划进行的更改。例如:
git checkout -b fix-npe-issue4.将更改提交到特性分支
如果你在更改中创建了任何新文件,则需要将其添加到刚创建的分支中。
git add <filename>对于所做的所有更改,你必须将它们提交到分支。确保添加有效的提交消息(根据项目的约定):
git commit -m "Fixed the NPE issue due to a null key used in cache"5.将特性分支推到你fork的仓库
现在是时候将你的提交推送到fork的仓库中了:
git push origin fix-npe-issue6.针对主仓库提出Pull Request(PR)
将代码推送到fork后的站群服务器仓库后,就可以针对主仓库提交PR了。单击“Pull Request”按钮以启动新的PR。
这将带你进入一个画面,在这个画面上,你的fork版本库中的变化将与主版本库中的代码进行比较。你可以在提交更改之前查看更改并提供有效的更改描述。
7.处理评论并合并PR
代码维护人员通常会针对你所做的更改返回某些评论,这可以是功能上的改变,也可以是修饰性的改变,比如格式等等。一旦你做出了这些更改,只需将它们推到你的分支,PR就会自动更新。
一旦你的修改没有什么不妥的话,维护人员将把它们合并到主仓库中。恭喜你!!你现在正式成为一名开源贡献者了。
8.将主存储库作为上游添加到克隆仓库中
除了你之外,许多其他开发人员还一直将其代码合并到主存储库中,我们需要与它的源码下载分支库连续进行同步,以获取最新的代码。
你克隆的存储库已链接到fork后仓库了,为了使fork的仓库与主仓库保持同步,你需要通过在克隆的仓库中添加主仓库作为上游(upstream)来连接它们。
git remote add upstream git@github.com:google/guava.git使用以下命令验证上游设置是否正确:
git remote -v它应该显示以下值,以确认源和上游指向正确的仓库:
origin git@github.com:theawesomenayak/guava.git (fetch) origin git@github.com:theawesomenayak/guava.git (push) upstream git@github.com:google/guava.git (fetch) upstream git@github.com:google/guava.git (push)9.从上游更新你的master分支
设置上游后,你可以提取其他开发人员在主仓库中所做的更改,这将更新本地计算机上的克隆仓库:
git pull upstream master10.将主分支push到你的fork仓库
一旦你在你的本地机器上有了所有的更新,你将需要把它们推送到你的fork后的仓库中,使其与主仓库同步。
git push origin master(可选)删除特性分支
特性合并到主仓库后,便不再需要它,可以将其删除:
git branch -d fix-npe-issue你还可以从fork的仓库中删除远程分支:
git push origin --delete fix-npe-issue最后为GitHub项目做贡献可能会很棘手,这取决于有多少开发人员同时在做。希望这篇文章能为你扫清GitHub贡献的流程,让你的开发周期变得更简单一些。
本文转载自微信公众号「前端全栈开发者」,可以通过以下二维码关注。转载本文请联系前端全栈开发者公众号。