成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

使用Git Submodule可能遇到的坑

移動開發 Android
隨著近幾年的發展,Git已經成為開源界的標準的版本控制工具。開源界的重量級項目,如Linux, Android, Eclipse, Gnome, KDE, Qt, ROR, Debian,無一例外的都是使用git來進行版本控制。在使用的過程中,作者發現了一些問題,在此分享給大家。

 

[[72462]]

前言

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

在使用了git submodule一段時間后,我發現了一些submodule的問題,在此分享給大家。
更新submodule的坑

  submodule項目和它的父項目本質上是2個獨立的git倉庫。只是父項目存儲了它依賴的submodule項目的版本號信息而已。如果你的同事更新了submodule,然后更新了父項目中依賴的版本號。你需要在git pull之后,調用 git submodule update來更新submodule信息。

 

  這兒的坑在于,如果你git pull之后,忘記了調用 git submodule update,那么你極有可能再次把舊的submodule依賴信息提交上去。對于那些習慣使用 git commit -a的人來說,這種危險會更大一些。所以建議大家:
1.git pull之后,立即執行git status, 如果發現submodule有修改,立即執行git submodule update
2.盡量不要使用 git commit -a, git add命令存在的意義就是讓你對加入暫存區的文件做二次確認,而 git commit -a相當于跳過了這個確認過程。

 

  更復雜一些,如果你的submodule又依賴了submodule,那么很可能你需要在git pull 和 git submodule update之后,再分別到每個submodule中再執行一次git submodule update,這里可以使用 git submodule foreach命令來實現: git submodule foreach git submodule update

 

修改submodule的坑

  有些時候你需要對submodule做一些修改,很常見的做法就是切到submodule的目錄,然后做修改,然后commit和push。

 

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

 

  如果你不慎忘記切換到master分支,又做了提交,可以用cherry-pick命令挽救。具體做法如下:
1.用 git checkout master 將HEAD從游離狀態切換到 master 分支, 這時候,git會報Warning說有一個提交沒有在branch上,記住這個提交的change-id(假如change-id為 aaaa)
2.用 git cherry-pick aaaa 來將剛剛的提交作用在master分支上
3.用 git push 將更新提交到遠程版本庫中

 

  以下是相關命令的操作示范和命令行輸出結果:
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

 

使用第三方工具

  對于submodule的重度使用者,有幾個工具可作推薦:
1.Repo Google用于管理Android項目的工具。
2.Gitslave
3.Git Subtree

  以上工具,我都沒有實際用過,所以無法提供更多信息。

 

Tips

  由于常常使用submodule的相關命令,可以在 ~/.gitconfig文件中將其設置別名,方便操作,我設置的所有相關別名如下:
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》
 

來源:唐巧的技術博客

責任編輯:佚名 來源: cocoachina
相關推薦

2018-07-16 14:23:30

代碼Android問題

2018-02-07 11:15:07

Vagrant使用問題

2023-04-04 08:38:27

命令Git倉庫

2024-10-06 13:41:25

2017-07-14 09:29:45

AndroidWebview

2016-03-23 11:03:40

2021-10-15 06:58:41

psycopg2綠色版 Python

2017-08-01 05:44:10

Dockerweave虛擬機

2024-09-09 08:02:27

2024-09-09 09:08:28

2017-06-23 11:20:00

DockerWeave內核

2021-03-18 14:47:42

Jenkins git submodu代碼

2019-01-07 14:36:36

Go系統開源庫

2021-08-29 18:36:17

MySQL技術面試題

2017-09-27 15:20:23

PHPerLaravelMysql

2023-02-28 16:26:46

推薦系統模塊

2020-05-12 14:57:06

git commit代碼前端

2015-02-10 11:25:59

AndroidiOS微軟

2020-12-30 09:55:56

鴻蒙HarmonyOS環境搭建

2016-12-30 11:10:32

Hadoop開發JVM
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 成人网av | 91免费入口 | 国产日韩一区 | 欧美色综合天天久久综合精品 | 一区二区中文字幕 | 91精品国模一区二区三区 | 精品久 | 91精品国产综合久久久久久丝袜 | 精品99爱视频在线观看 | 国内自拍真实伦在线观看 | 国产欧美日韩一区二区三区在线 | dy天堂| 成在线人视频免费视频 | 毛片在线看片 | 日本中文字幕日韩精品免费 | 99精品久久久久久 | 亚洲视频一区二区三区 | 91久久 | 九色91视频 | 性色综合 | 欧美www在线观看 | 激情影院久久 | 欧美性网站 | 精品99爱视频在线观看 | 蜜桃视频在线观看免费视频网站www | 亚洲人成人一区二区在线观看 | 日韩一区二区在线播放 | 一区二区在线视频 | 国产亚洲一区二区三区在线 | 国产精品99久久久久久宅男 | 欧美性成人| 国产一区二区三区久久久久久久久 | www.av在线 | 精品一二 | 激情婷婷| 国产成人精品午夜视频免费 | 欧美一级淫片免费视频黄 | 欧美日韩亚洲一区 | 国产精品一区二区免费 | 国产精品久久久久久av公交车 | 亚洲国产aⅴ成人精品无吗 亚洲精品久久久一区二区三区 |