码农朋友们都知道,gitHub是一个面向开源及私有软件项目的托管平台,上面托管了众多的优秀的项目,好比linux内核源码、git源码、机器学习框架tensorflow等等。固然,除了这些顶尖项目外,还有海量的高手开发的优秀项目。全部的这些项目,咱们均可觉得它贡献代码。linux
那么,要如何为这些项目贡献代码呢?咱们下面以实例来说解。git
好比说,如今gitHub上有个很牛逼的项目githubTest,它的做者是Alvin,项目地址以下:github
https://github.com/yychuyu/githubTest
如今Harry看到了这个项目,想要对它进行贡献代码。想要达到这个目的,Harry要完成下图的这些步骤:框架
1. fork机器学习
Harry在找到这个项目以后,点击右上角的「fork」按钮。稍等片刻后,就会在Harry的帐号下克隆了一个同样的项目githubTest,包括文件,提交历史,issues,和其他一些东西。学习
2. clonefetch
经过fork以后,Harry的帐号下也有了githubTest这个项目,但还不能对它进行编译、修改(实际上是能够修改,可是不建议)。人工智能
这时,能够经过git clone命令,将这个项目clone到本身的电脑里。
3d
3. update a file & 4. commitcode
接下来,Harry就能够大显身手了,能够自由对这个项目进行修改。可是,不建议在master分支直接修改,建议在master分支基础上切出一个dev分支,而后在dev分支上自由发挥。修改完以后,再将dev分支merge到master分支。
5. push
在本身的电脑上修改好代码以后,再使用git push命令将改动同步到本身的gitHub项目仓库里。
经过这个操做后,就能够在代码仓库里看到本身的提交了。
6. pull request
接下来,就是向原做者Alvin提交你的代码了。首先点击文件列表上的「New pull request」。
以后,gitHub会自动对源仓库分支及本身仓库分支代码进行比对,看看是否有冲突。若是它显示「Able to merge」的话,Harry就能够点击下面的「Create pull request」绿色按钮,进行代码提交。
再以后,系统会要求你写一段注释,其实也可不写。但最好写一下,跟做者说明一下你改动了什么,为啥这么改。
经过以上6步,原做者Alvin就会收到一个pull request,以下图:
而后,Alvin能够点进去,看看Harry具体提交了一些什么修改。若是他以为这个修改确实够niubility的话,它就能够点击「merge pull request」,将Harry的提交集成到本身的项目里。
至此,功德圆满,Harry顺利完成一次对项目githubTest的代码贡献。
可是,这个项目实在太出众了,不少高手看到了并贡献了众多代码。好比如今Alvin本身提交了一个文件:
如今原做者项目已经发生了改变,那Harry帐号下的githubTest如何与原做者Alvin的项目保持同步呢?Harry须要作如下三步操做:
1. fetch
如今代码不一样步了,咱们要先把Alvin仓库的代码fetch到本身电脑的仓库下。注意,这是在本身电脑上操做,不是在github上操做。
git fetch git@github.com:yychuyu/githubTest.git master:latest
上面这条命令,git fetch 以后 的那部分,是原做者Alvin项目git地址,经过点击原项目「clone or download」按钮能够看到。再以后master:latest这部分,master是原项目分支,latest是本身项目分支。若是latest分支不存在的话,将自动建立。其实也能够将代码fetch到本身的master分支,但也不建议这么作。
2. merge
代码fetch到latest分支以后,再切到master分支,再使用git merge命令将最新代码合并到master分支。
3. push
如今,Harry电脑上的代码与原项目代码保持同步了。咱们再使用git push命令,就能够将最新代码推到Harry帐号下githubTest项目里
以上的三个步骤具体操做过程以下图示。
接下来,Harry就能够在此基础上,继续贡献本身的代码了。
更多精彩内容,请关注公众号良许Linux,公众内回复1024可免费得到5T技术资料,包括:Linux,C/C++,Python,树莓派,嵌入式,Java,人工智能,等等。公众号内回复进群,邀请您进高手如云技术交流群。
公众号:良许Linux