碼農(nóng)朋友們都知道,GitHub是一個(gè)面向開源及私有軟件項(xiàng)目的托管平臺(tái),上面托管了眾多的優(yōu)秀的項(xiàng)目,比如Linux內(nèi)核源碼、Git源碼、機(jī)器學(xué)習(xí)框架Tensorflow等等。當(dāng)然,除了這些頂尖項(xiàng)目外,還有海量的高手開發(fā)的優(yōu)秀項(xiàng)目。所有的這些項(xiàng)目,我們都可以為它貢獻(xiàn)代碼。
那么,要如何為這些項(xiàng)目貢獻(xiàn)代碼呢?我們下面以實(shí)例來(lái)講解。
比如說(shuō),現(xiàn)在GitHub上有個(gè)很牛逼的項(xiàng)目githubTest,它的作者是Alvin,項(xiàng)目地址如下:https://github.com/yychuyu/githubTest。
現(xiàn)在Harry看到了這個(gè)項(xiàng)目,想要對(duì)它進(jìn)行貢獻(xiàn)代碼。想要達(dá)到這個(gè)目的,Harry要完成下圖的這些步驟:
1. fork
Harry在找到這個(gè)項(xiàng)目之后,點(diǎn)擊右上角的「fork」按鈕。稍等片刻后,就會(huì)在Harry的賬號(hào)下克隆了一個(gè)一樣的項(xiàng)目githubTest,包括文件、提交歷史、issues、和其余一些東西。
2. clone
通過(guò)fork之后,Harry的賬號(hào)下也有了githubTest這個(gè)項(xiàng)目,但還不能對(duì)它進(jìn)行編譯、修改(其實(shí)是可以修改,但是不建議)。
這時(shí),可以通過(guò)git clone命令,將這個(gè)項(xiàng)目clone到自己的電腦里。
3. update a file & 4. commit
接下來(lái),Harry就可以大顯身手了,可以自由對(duì)這個(gè)項(xiàng)目進(jìn)行修改。
但是,不建議在master分支直接修改,建議在master分支基礎(chǔ)上切出一個(gè)dev分支,然后在dev分支上自由發(fā)揮。修改完之后,再將dev分支merge到master分支。
5. push
在自己的電腦上修改好代碼之后,再使用git push命令將改動(dòng)同步到自己的GitHub項(xiàng)目倉(cāng)庫(kù)里。
通過(guò)這個(gè)操作后,就可以在代碼倉(cāng)庫(kù)里看到自己的提交了。
6. pull request
接下來(lái),就是向原作者Alvin提交你的代碼了。首先點(diǎn)擊文件列表上的「New pull request」。
之后,GitHub會(huì)自動(dòng)對(duì)源倉(cāng)庫(kù)分支及自己倉(cāng)庫(kù)分支代碼進(jìn)行比對(duì),看看是否有沖突。如果它顯示「Able to merge」的話,Harry就可以點(diǎn)擊下面的「Create pull request」綠色按鈕,進(jìn)行代碼提交。
再之后,系統(tǒng)會(huì)要求你寫一段注釋,其實(shí)也可不寫。但最好寫一下,跟作者說(shuō)明一下你改動(dòng)了什么,為什么這么改。
通過(guò)以上6步,原作者Alvin就會(huì)收到一個(gè)pull request,如下圖:
然后,Alvin可以點(diǎn)進(jìn)去,看看Harry具體提交了一些什么修改。如果他覺(jué)得這個(gè)修改確實(shí)夠niubility的話,它就可以點(diǎn)擊「merge pull request」,將Harry的提交集成到自己的項(xiàng)目里。
至此,功德圓滿,Harry順利完成一次對(duì)項(xiàng)目githubTest的代碼貢獻(xiàn)。
但是,這個(gè)項(xiàng)目實(shí)在太出眾了,很多高手看到了并貢獻(xiàn)了眾多代碼。比如現(xiàn)在Alvin自己提交了一個(gè)文件:
現(xiàn)在原作者項(xiàng)目已經(jīng)發(fā)生了改變,那Harry賬號(hào)下的githubTest如何與原作者Alvin的項(xiàng)目保持同步呢?Harry需要做以下三步操作:
1. fetch
現(xiàn)在代碼不同步了,我們要先把Alvin倉(cāng)庫(kù)的代碼fetch到自己電腦的倉(cāng)庫(kù)下。注意,這是在自己電腦上操作,不是在GitHub上操作。
gitfetchgit@github.com:yychuyu/githubTest.gitmaster:latest
上面這條命令,git fetch 之后的那部分,是原作者Alvin項(xiàng)目git地址,通過(guò)點(diǎn)擊原項(xiàng)目「clone or download」按鈕可以看到。再之后master:latest這部分,master是原項(xiàng)目分支,latest是自己項(xiàng)目分支。
如果latest分支不存在的話,將自動(dòng)創(chuàng)建。其實(shí)也可以將代碼fetch到自己的master分支,但也不建議這么做。
2. merge
代碼fetch到latest分支之后,再切到master分支,再使用git merge命令將最新代碼合并到master分支。
3. push
現(xiàn)在,Harry電腦上的代碼與原項(xiàng)目代碼保持同步了。我們?cè)偈褂胓it push命令,就可以將最新代碼推到Harry賬號(hào)下githubTest項(xiàng)目里。
以上的三個(gè)步驟具體操作過(guò)程如下圖示:
接下來(lái),Harry就可以在此基礎(chǔ)上,繼續(xù)貢獻(xiàn)自己的代碼了。
-
機(jī)器學(xué)習(xí)
+關(guān)注
關(guān)注
66文章
8503瀏覽量
134618 -
GitHub
+關(guān)注
關(guān)注
3文章
483瀏覽量
17686
原文標(biāo)題:如何在 GitHub 上大顯身手?
文章出處:【微信號(hào):mcuworld,微信公眾號(hào):嵌入式資訊精選】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
發(fā)布評(píng)論請(qǐng)先 登錄
教你如何快速在Github上為RT-Thread貢獻(xiàn)代碼

上傳本地項(xiàng)目代碼到github
Github發(fā)布史上最大更新
【直播回顧】戰(zhàn)碼先鋒第七期:三方應(yīng)用開發(fā)者如何為開源做貢獻(xiàn)
來(lái)自GitHub的安全威脅應(yīng)該如何應(yīng)對(duì)
github是什么_github有什么用
github入門到上傳本地項(xiàng)目步驟
github使用教程_github菜鳥教程

2018 年 2 月份 GitHub 上最熱門的開源項(xiàng)目
微軟北極代碼庫(kù)項(xiàng)目,GitHub代碼可存儲(chǔ)500年
GitHub無(wú)故封禁開源項(xiàng)目引網(wǎng)友不滿 都是開源代碼受管制惹的禍?
如何對(duì)OpenHarmony貢獻(xiàn)代碼

上傳本地項(xiàng)目代碼到github

如何使用Github高效率的查找項(xiàng)目

評(píng)論