本文作者黃昱俊,國資企業(yè)投資部總經(jīng)理,主要負責(zé)投資部門建設(shè)、投資流程管理、投后資源管理。歷經(jīng)10年,從醫(yī)療器械研發(fā)工程師到投資管理的蛻變,業(yè)余嘗試ETF量化投資。
本文介紹如何在GitHub上更新Fork以及PullRequest給源項目。
在GitHub上更新Fork
經(jīng)常遇到的是Fork一個項目之后,源項目的作者做了新的更改,如果沒有同步到我自己的Fork,我所做的更新進行Pull Request后,會產(chǎn)生沖突;因此在更新文件之前、至少是Pull Request之前,應(yīng)當(dāng)要更新自己的Fork的。
更新Fork的方法有很多,Git寫代碼是很好的,當(dāng)小白通常比較難做,步驟缺了就經(jīng)常不奏效;所以我自己親測了一個GitHub上更新Fork的方法,做一個教程,與朋友們共勉;廢話少說,步驟如下。
一、進入自己Fork來的項目,按New Pull Request按鈕,新建一個Pull Request(簡稱:PR)。
二、如果自己還沒有修改過Fork項目的文件,那么此時可以點擊switching the base,切換到基于我自己的Fork項目。
如果已經(jīng)修改或更新過Fork項目的文件,那么可以通過選擇Base Fork和Head Fork來從源項目更新到我自己的Fork項目。
這里有個小技巧:在默認狀態(tài)下,會是Base源項目,Head我自己的Fork項目;這樣選擇任何一個時,會調(diào)到某個無法更新的頁面;解決方法是先Base或Head一個其他人的賬號下的Fork,接著選擇Head/Base源項目或我自己的Fork項目,這樣就不會出現(xiàn)Base和Head都是自己或者都是源項目的情況。
三、Base和Head設(shè)置完,就進入Comparing Changes頁面,確認一下Base和Head,以及最新的更新內(nèi)容。
內(nèi)容沒問題就Create PR了,即上圖綠色箭頭所指向的綠色按鈕;接著輸入主題,Create。
四、新Create的PR在哪里可以找到呢?進入我自己的Fork項目,導(dǎo)航條上的PR進入,看到Open的有一個,就是剛才更新的。
點擊進入確認一下。
五、把源項目的更新Merge到我的Fork項目。
Confirm Merge,確定這個更新;
可以看到,這個PR已經(jīng)更新完成,呈紫色的Merge狀態(tài)。
六、最后驗證一下是否更新到最新的項目,因為已知是更新了Pattern Recognition,所以直接進入。
查看到下面5個是最新修改的,15個小時之前修改了內(nèi)容。
至此整個更新Fork的方法步驟已完成,玩得愉快!
將更新的Fork項目PullRequest給源項目
我們Fork項目之后進行了修改或添加新文件,需要Pull Request(簡稱:PR)給源項目,讓作者Merge融入到他的源項目里。
在PR之前,甚至開始修改或創(chuàng)建新文件之前,先看看源項目是否有更新,如有更新,可按第一部分內(nèi)容,先更新自己的Fork項目,再做創(chuàng)建新文件,老司機說這樣沖突比較少。
一、看到別人的好項目,如何“據(jù)為己有”?Fork一下咯!
點擊Fork,會進入Fork進行中的界面;
Fork完成后,可以在自己的主頁(Your Profile)看到Fork的項目。
二、可以通過Create new file或upload file新建或上傳文件,要注意的是:上傳的文件會把原來同名文件覆蓋掉!
這里的會有文件上傳的進度條,如下圖:共13個文件,已上傳9個;上傳完成的文件會在下方顯示。
這個上傳文件由于服務(wù)器在國外的緣故,死慢死慢,經(jīng)常就廢了,如下圖。
當(dāng)看到下面這個Processing your files…頁面,那就恭喜你了,經(jīng)過幾十次的上傳,總算work了;如果出現(xiàn)一片空白的頁面,那么只好重復(fù)choose your files,再次Confirm Changes。
三、新建PR:可以在Fork項目的根目錄下,或者任意的目錄下,Pull Request。
Pull Request后會進入Comparing changes頁面,核對一下Base Fork和Head Fork(藍色圓圈)、以及更新的內(nèi)容(紫色方框);由于已經(jīng)更新過最新的源項目內(nèi)容,與源項目同步好了,所以此時顯示“Able to merge”(紅圈綠字);一切就緒,點擊Create創(chuàng)建PR。
輸入主題,并Create PR;
這時可以看到已經(jīng)將這個更新PR給源項目作者,PR序號為#52,狀態(tài)open。
四、源項目作者Merge此PR,將此次的更改融入到源項目,并形成Commits記錄。
序號#52的PR已經(jīng)Merge:
進入源項目,查看Commit記錄:
至此,整個Fork、修改或創(chuàng)建文件、Pull Request以及Merge的步驟已完成,玩的愉快!
-
代碼
+關(guān)注
關(guān)注
30文章
4723瀏覽量
68236 -
GitHub
+關(guān)注
關(guān)注
3文章
465瀏覽量
16359
原文標(biāo)題:如何更好地玩轉(zhuǎn)GitHub?
文章出處:【微信號:rgznai100,微信公眾號:rgznai100】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
相關(guān)推薦
評論