自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

使用Git Submodule可能遇到的坑

移動(dòng)開(kāi)發(fā) Android
隨著近幾年的發(fā)展,Git已經(jīng)成為開(kāi)源界的標(biāo)準(zhǔn)的版本控制工具。開(kāi)源界的重量級(jí)項(xiàng)目,如Linux, Android, Eclipse, Gnome, KDE, Qt, ROR, Debian,無(wú)一例外的都是使用git來(lái)進(jìn)行版本控制。在使用的過(guò)程中,作者發(fā)現(xiàn)了一些問(wèn)題,在此分享給大家。

 

[[72462]]

前言

  對(duì)于一些比較大的工程,為了便于復(fù)用,常常需要抽取子項(xiàng)目。例如我開(kāi)發(fā)的猿題庫(kù)客戶(hù)端現(xiàn)在包括3門(mén)考試,客戶(hù)端涉及的公共UI、公共底層邏輯、公共的第三方庫(kù)、以及公共的答題卡掃描算法就被我分別抽取成了子項(xiàng)目。這些子項(xiàng)目都以git submodule的形式,增加到工程中。

在使用了git submodule一段時(shí)間后,我發(fā)現(xiàn)了一些submodule的問(wèn)題,在此分享給大家。
更新submodule的坑

  submodule項(xiàng)目和它的父項(xiàng)目本質(zhì)上是2個(gè)獨(dú)立的git倉(cāng)庫(kù)。只是父項(xiàng)目存儲(chǔ)了它依賴(lài)的submodule項(xiàng)目的版本號(hào)信息而已。如果你的同事更新了submodule,然后更新了父項(xiàng)目中依賴(lài)的版本號(hào)。你需要在git pull之后,調(diào)用 git submodule update來(lái)更新submodule信息。

 

  這兒的坑在于,如果你git pull之后,忘記了調(diào)用 git submodule update,那么你極有可能再次把舊的submodule依賴(lài)信息提交上去。對(duì)于那些習(xí)慣使用 git commit -a的人來(lái)說(shuō),這種危險(xiǎn)會(huì)更大一些。所以建議大家:
1.git pull之后,立即執(zhí)行g(shù)it status, 如果發(fā)現(xiàn)submodule有修改,立即執(zhí)行g(shù)it submodule update
2.盡量不要使用 git commit -a, git add命令存在的意義就是讓你對(duì)加入暫存區(qū)的文件做二次確認(rèn),而 git commit -a相當(dāng)于跳過(guò)了這個(gè)確認(rèn)過(guò)程。

 

  更復(fù)雜一些,如果你的submodule又依賴(lài)了submodule,那么很可能你需要在git pull 和 git submodule update之后,再分別到每個(gè)submodule中再執(zhí)行一次git submodule update,這里可以使用 git submodule foreach命令來(lái)實(shí)現(xiàn): git submodule foreach git submodule update

 

修改submodule的坑

  有些時(shí)候你需要對(duì)submodule做一些修改,很常見(jiàn)的做法就是切到submodule的目錄,然后做修改,然后commit和push。

 

  這里的坑在于,默認(rèn)git submodule update并不會(huì)將submodule切到任何branch,所以,默認(rèn)下submodule的HEAD是處于游離狀態(tài)的(‘detached HEAD’ state)。所以在修改前,記得一定要用git checkout master將當(dāng)前的submodule分支切換到master,然后才能做修改和提交。

 

  如果你不慎忘記切換到master分支,又做了提交,可以用cherry-pick命令挽救。具體做法如下:
1.用 git checkout master 將HEAD從游離狀態(tài)切換到 master 分支, 這時(shí)候,git會(huì)報(bào)Warning說(shuō)有一個(gè)提交沒(méi)有在branch上,記住這個(gè)提交的change-id(假如change-id為 aaaa)
2.用 git cherry-pick aaaa 來(lái)將剛剛的提交作用在master分支上
3.用 git push 將更新提交到遠(yuǎn)程版本庫(kù)中

 

  以下是相關(guān)命令的操作示范和命令行輸出結(jié)果:
1. ui_common git:(df697f9) git checkout master
2.Warning: you are leaving 1 commit behind, not connected to
3.any of your branches:
4.
5.  df697f9 forget to check out master
6.
7.If you want to keep them by creating a new branch, this may be a good time
8.to do so with:
9.
10. git branch new_branch_name df697f911e5a0f09d883f8f360977e470c53d81e
11.
12.Switched to branch 'master'
13. ui_common git:(master) git cherry-pick df697f9

 

使用第三方工具

  對(duì)于submodule的重度使用者,有幾個(gè)工具可作推薦:
1.Repo Google用于管理Android項(xiàng)目的工具。
2.Gitslave
3.Git Subtree

  以上工具,我都沒(méi)有實(shí)際用過(guò),所以無(wú)法提供更多信息。

 

Tips

  由于常常使用submodule的相關(guān)命令,可以在 ~/.gitconfig文件中將其設(shè)置別名,方便操作,我設(shè)置的所有相關(guān)別名如下:
1.[alias]
2.  st = status -s
3.  ci = commit
4.  l = log --oneline --decorate -12 --color
5.  ll = log --oneline --decorate --color
6.  lc = log --graph --color
7.  co = checkout
8.  br = branch
9.  rb = rebase
10.  dci = dcommit
11.  sbi = submodule init
12.  sbu = submodule update
13.  sbp = submodule foreach git pull
14.  sbc = submodule foreach git co master


參考鏈接
1.《why-your-company-shouldnt-use-git-submodules》 (需翻墻)

2.《Git_submodule_tutorial》
 

來(lái)源:唐巧的技術(shù)博客

責(zé)任編輯:佚名 來(lái)源: cocoachina
相關(guān)推薦

2018-07-16 14:23:30

代碼Android問(wèn)題

2018-02-07 11:15:07

Vagrant使用問(wèn)題

2023-04-04 08:38:27

命令Git倉(cāng)庫(kù)

2024-10-06 13:41:25

2017-07-14 09:29:45

AndroidWebview

2017-08-01 05:44:10

Dockerweave虛擬機(jī)

2024-09-09 08:02:27

2021-10-15 06:58:41

psycopg2綠色版 Python

2016-03-23 11:03:40

2024-09-09 09:08:28

2021-03-18 14:47:42

Jenkins git submodu代碼

2017-06-23 11:20:00

DockerWeave內(nèi)核

2019-01-07 14:36:36

Go系統(tǒng)開(kāi)源庫(kù)

2021-08-29 18:36:17

MySQL技術(shù)面試題

2023-02-28 16:26:46

推薦系統(tǒng)模塊

2017-09-27 15:20:23

PHPerLaravelMysql

2020-05-12 14:57:06

git commit代碼前端

2020-12-30 09:55:56

鴻蒙HarmonyOS環(huán)境搭建

2021-03-18 09:18:12

python爬蟲(chóng)

2016-12-30 11:10:32

Hadoop開(kāi)發(fā)JVM
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)