第 3 章 Github.com
主畫面有好幾個tab:Code, Issue, Pull requests, Projects, Wiki, Insights 及 Settings
3.1 Code
所有備份(含歷史事件簿)儲存的地方。
- 點
可在線上進行歷史改變revert的動作。
3.2 Fork
由於HelloGithub為公開repo,任何Github用戶皆可拿回去使用,這個拿個備份回去使用的動作叫Fork。
- 點
即可「取得備份」。
HelloGithub狀態:
- tpemartin: 擁有者
使用者PoMingChen取得tpemartin/HelloGithub repo備份。
- PoMingChen: Fork使用者
在Github雲端平台fork的repo會放在自己的帳戶內。
自己擁有的repo
複製別人的repo
3.2.1 Clone(複製回主機)
雲端的repo要在Desktop進行clone才會抓回到你主機供你修改使用。
data:image/s3,"s3://crabby-images/95d4f/95d4f66ff22a03aab62a8eab2de7c0b84e9c85ec" alt="Clone 1"
Clone 1
data:image/s3,"s3://crabby-images/3d5a7/3d5a77e33d44ebb7592b9f177b270767946b758f" alt="Clone 2"
Clone 2
3.3 Collaboration
善用Fork可以促進團隊合作效率。用法是組長為repo擁有者,組員各自fork一份repo回自己雲端與主機。
以下說明皆以tpemartin為組長,PoMingChen為fork組員。
3.3.1 Edit different files
組長tpemartin(上方)與組員PM(下方)各自編輯不同文件後commit且push上傳。
data:image/s3,"s3://crabby-images/e40d4/e40d414738b61e9baacbf5fd5ad6cb78949747a6" alt="編輯不同檔案"
編輯不同檔案
3.3.2 組員送出Pull request
PM 想回報tpemartin更新進度,並請tpemartin收錄他的更新變動:
data:image/s3,"s3://crabby-images/9f125/9f125af8eb30836b907500a66baab967e3854204" alt="在Desktop進行Pull request: 選Create Pull Request"
在Desktop進行Pull request: 選Create Pull Request
data:image/s3,"s3://crabby-images/b6b23/b6b232683ef0076bf0e7f519dd5cdca795c0ccc6" alt="GitHub視窗跳出Open a pull request"
GitHub視窗跳出Open a pull request
3.3.3 組長Merge pull request
tpemartin在Github.com收到pull request通知。依以下步驟處理:
data:image/s3,"s3://crabby-images/1ce66/1ce66c675eb73ecd67b60d2faeb7c3be66036b63" alt="步驟1"
步驟1
data:image/s3,"s3://crabby-images/9473c/9473c8ae26bd813c9aa96d5a4576fe8a869ff11a" alt="步驟2"
步驟2
data:image/s3,"s3://crabby-images/7cfc7/7cfc74beab5f9e494f5ec76f64c1dcfd257e1ba6" alt="步驟3"
步驟3
data:image/s3,"s3://crabby-images/89098/890981f834d7755323301d738de3d27b9c90be29" alt="步驟4"
步驟4
3.3.4 更新突衝
有時工作沒協調好,組長與組員同時在編輯一份檔案,如下圖。
若組長與組員皆commit且push了這個更新,而組員送出pull request,此時組員會看到以下有警告訊息的pull request。
data:image/s3,"s3://crabby-images/a5789/a5789333ff85ead49b030413d7f17211deb3edb7" alt=""
data:image/s3,"s3://crabby-images/1b156/1b15621b9ff5fcdc4c9b4e9a1f78b941391f5b5a" alt=""
data:image/s3,"s3://crabby-images/c8054/c80549be9cb3eee8ccf39c06ca2177cbdb962883" alt=""
組長tpemartin在Github.com收到pull request,必需要解決衝突。
data:image/s3,"s3://crabby-images/1945a/1945a6269dd5bbbb45699cd12843ca440b5fba97" alt=""
data:image/s3,"s3://crabby-images/12fa8/12fa80bc6927dd9b930b8c8f934dec916ff7511a" alt=""
data:image/s3,"s3://crabby-images/cb7dd/cb7ddff9281a2b439f1ffd24ff3504e9dd0c39e1" alt=""
data:image/s3,"s3://crabby-images/cb7dd/cb7ddff9281a2b439f1ffd24ff3504e9dd0c39e1" alt=""
data:image/s3,"s3://crabby-images/d47cf/d47cfe8eca6c484b427ae9f35382862b9d98174c" alt=""
data:image/s3,"s3://crabby-images/4356b/4356bba53b4288d9f2508c11f153fe783323be3f" alt=""
data:image/s3,"s3://crabby-images/a049f/a049f29d8843ea6a78818b9b028c35eb8ff82a61" alt=""
data:image/s3,"s3://crabby-images/751f0/751f06cbea38a2172c241029f1e62494352e16c5" alt=""
data:image/s3,"s3://crabby-images/68af2/68af2a92c734abb041d8fec3284547e8f85c6a6f" alt=""
3.4 組員更新Forked repo
組長的repo會因為處理過不同組員的pull request而和組員的repo內容不同,由於組長的repo應該是最新最完整的,組長在整合進度到一段落,應該通知組員更新自己的forked repo。
以下是組員更新forked repo的步驟:
data:image/s3,"s3://crabby-images/2d41b/2d41bbda8731316d3fe9755ee4719e81378ec583" alt="步驟0:點選New pull request"
步驟0:點選New pull request
data:image/s3,"s3://crabby-images/6d2b3/6d2b331bfdc5ad93f96488ad2a8408669f47a6b4" alt="步驟1:檢視差異"
步驟1:檢視差異
data:image/s3,"s3://crabby-images/d74a9/d74a97e34916ecff5c26f2d67a6ed96dc336666b" alt="步驟2:base fork放組員的forked repo"
步驟2:base fork放組員的forked repo
data:image/s3,"s3://crabby-images/9ebc1/9ebc10d0d215a075c4473e4b1c9ac78862ee6ace" alt="步驟3:點選compare across forks"
步驟3:點選compare across forks
data:image/s3,"s3://crabby-images/cd33a/cd33ac357b1738cc910eebb16a36f2ba827afb27" alt="步驟4:Head fork放組長的repo"
步驟4:Head fork放組長的repo
data:image/s3,"s3://crabby-images/330b9/330b9edc8e703783fe408cdb7d2a80302b765abc" alt="步驟5:點Create pull request"
步驟5:點Create pull request
data:image/s3,"s3://crabby-images/e3a98/e3a98a28ea5214a470b0f94935111593251f744a" alt="步驟6: 點Merge pull request"
步驟6: 點Merge pull request
- 以上步驟只是雲端上的更新,記得用Desktop更新自己電腦的。