Git Submodule: Difference between revisions

From Chorke Wiki
Jump to navigation Jump to search
No edit summary
 
(26 intermediate revisions by the same user not shown)
Line 1: Line 1:
Git submodule is very simple where you have to aware about few things. Those are as following:
1. After addition of submodule, you have commit main module must
2. After pull of submodule, you have to pull/commit main module
3. After commit of submodule, you have to commit main module
==Structure==
==Structure==
<source lang="bash">
<source lang="bash">
Line 8: Line 13:
   │  └─ AcademiaApp
   │  └─ AcademiaApp
   ├─ server
   ├─ server
   │  ├─ academia-init-ckiapi.git
   │  ├─ academia-apps-ckiapi.git
   │  ├─ academia-init-ckirui.git
   │  ├─ academia-apps-ckigui.git
   │  └─ academia-init-ckiapp.git
   │  └─ academia-apps-ckiapp.git
   └─ client
   └─ client
     ├─ AcademiaApi
     ├─ AcademiaApi
Line 17: Line 22:
'
'
cd /opt/chorke/academia/server/
cd /opt/chorke/academia/server/
git init --bare academia-init-ckiapi.git
git init --bare academia-apps-ckiapi.git
git init --bare academia-init-ckigui.git
git init --bare academia-apps-ckigui.git
git init --bare academia-init-ckiapp.git
git init --bare academia-apps-ckiapp.git
</source>
</source>


Line 27: Line 32:
/opt/chorke/academia/master/AcademiaApi
/opt/chorke/academia/master/AcademiaApi
   ├─ .gitignore
   ├─ .gitignore
   ├─ LICENSE
   ├─ README.md
   └─ README.md
   └─ LICENSE
'
'
cd /opt/chorke/academia/master/AcademiaApi;git init
cd /opt/chorke/academia/master/AcademiaApi;git init
git remote add origin /opt/chorke/academia/server/academia-init-ckiapi.git
git remote add origin /opt/chorke/academia/server/academia-apps-ckiapi.git
git add --all; git commit -m 'initial commit'
git add --all; git commit -m 'initial commit'; git push origin master
git push origin master
</source>
</source>


Line 40: Line 44:
/opt/chorke/academia/master/AcademiaGui
/opt/chorke/academia/master/AcademiaGui
   ├─ .gitignore
   ├─ .gitignore
   ├─ LICENSE
   ├─ README.md
   └─ README.md
   └─ LICENSE
'
'
cd /opt/chorke/academia/master/AcademiaGui;git init
cd /opt/chorke/academia/master/AcademiaGui;git init
git remote add origin /opt/chorke/academia/server/academia-init-ckigui.git
git remote add origin /opt/chorke/academia/server/academia-apps-ckigui.git
git add --all; git commit -m 'initial commit'
git add --all; git commit -m 'initial commit'; git push origin master
git push origin master
</source>
</source>


Line 53: Line 56:
/opt/chorke/academia/master/AcademiaApp
/opt/chorke/academia/master/AcademiaApp
   ├─ .gitignore
   ├─ .gitignore
   ├─ LICENSE
   ├─ README.md
   └─ README.md
   └─ LICENSE
'
'
cd /opt/chorke/academia/master/AcademiaApp;git init
cd /opt/chorke/academia/master/AcademiaApp;git init
git remote add origin /opt/chorke/academia/server/academia-init-ckiapp.git
git remote add origin /opt/chorke/academia/server/academia-apps-ckiapp.git
git add --all; git commit -m 'initial commit'
git add --all; git commit -m 'initial commit'; git push origin master
git push origin master
</source>
</source>


<source lang="bash">
<source lang="bash" highlight="10,11,13,14">
:'
:'
git submodule add /opt/chorke/academia/server/academia-init-ckiapi.git
git submodule add /opt/chorke/academia/server/academia-apps-ckiapi.git
git submodule add /opt/chorke/academia/server/academia-init-ckigui.git
git submodule add /opt/chorke/academia/server/academia-apps-ckigui.git
git rm --cached academia-init-ckiapi; git rm --cached academia-init-ckigui
 
git rm --cached academia-apps-ckiapi; git rm --cached academia-apps-ckigui
git rm --cached .gitmodules; git reset --hard; git clean -fd
git rm --cached .gitmodules; git reset --hard; git clean -fd
rm -rf academia-init-cki*
rm -rf academia-apps-cki*
'
'
git submodule add /opt/chorke/academia/server/academia-init-ckiapi.git AcademiaApi
 
git submodule add /opt/chorke/academia/server/academia-init-ckigui.git AcademiaGui
git submodule add /opt/chorke/academia/server/academia-apps-ckiapi.git AcademiaApi
git submodule add /opt/chorke/academia/server/academia-apps-ckigui.git AcademiaGui


git config -f .gitmodules submodule.AcademiaApi.branch master
git config -f .gitmodules submodule.AcademiaApi.branch master
Line 81: Line 85:


==Client==
==Client==
<source lang="bash">
<source lang="bash" highlight="5">
#academia/client/AcademiaApp
# academia/client/AcademiaApp
cd /opt/chorke/academia/client/
cd /opt/chorke/academia/client/
git clone /opt/chorke/academia/server/academia-init-ckiapp.git AcademiaApp
git clone /opt/chorke/academia/server/academia-apps-ckiapp.git AcademiaApp
cd AcademiaApp
# cd AcademiaApp; git submodule init; git submodule update
git submodule init
cd AcademiaApp; git submodule update --init
git submodule update
 
vim HelloApp.txt;git add HelloApp.txt
git commit -m 'Hello App Added'
</source>


#AcademiaApp/AcademiaGui
===Wrong===
<source lang="bash" highlight="8-10">
# client/AcademiaApp/AcademiaGui
cd /opt/chorke/academia/client/AcademiaApp/AcademiaGui/
cd /opt/chorke/academia/client/AcademiaApp/AcademiaGui/
vim HelloGui.txt
vim HelloGui.txt; git add HelloGui.txt
cd ..
git commit -m 'Hello Gui Added'
 
git status; cd ..; git status
#academia/client/AcademiaApp
vim HelloApp.txt
git add --all; git commit -m 'Hello App Added'
git status
 
 
#AcademiaApp/AcademiaGui
cd AcademiaGui/
git add --all; git commit -m 'Hello Gui Added'
git status
cd ..


#academia/client/AcademiaApp
# academia/client/AcademiaApp
git status
git submodule status --recursive
git submodule status --recursive
git submodule foreach git pull origin master
git submodule foreach git push -u origin master
git submodule foreach git push -u origin master
git submodule foreach git pull origin master


#academia/master/AcademiaGui
# academia/master/AcademiaGui
cd /opt/chorke/academia/master/AcademiaGui/
cd /opt/chorke/academia/master/AcademiaGui/
git pull origin master
git pull origin master
</source>


#client/AcademiaApp/AcademiaGui
===Right===
<source lang="bash" highlight="3,8,22,27,28">
# client/AcademiaApp/AcademiaGui
cd /opt/chorke/academia/client/AcademiaApp/AcademiaGui/
cd /opt/chorke/academia/client/AcademiaApp/AcademiaGui/
git checkout master; vim HelloGui.txt
git checkout master; vim HelloGui.txt; git add HelloGui.txt
git add --all;git commit -m 'Hello GUI Added'
git commit -m 'Hello GUI Added'
git push origin master
git push origin master; cd ..
cd ..


#academia/client/AcademiaApp
# academia/client/AcademiaApp
git add AcademiaGui
git add AcademiaGui; git commit -m 'AcademiaGui updated'
git commit -m 'AcademiaGui updated'
git push origin master
git push origin master


# master/gui
# academia/master/AcademiaGui
cd /opt/chorke/academia/master/AcademiaGui/
cd /opt/chorke/academia/master/AcademiaGui/
vim HelloAdd.txt
vim HelloAdd.txt; git add HelloAdd.txt
git add HelloAdd.txt;git commit -m 'Hello Add Text File Added'
git commit -m 'Hello Add Text File Added'
git push origin master
git push origin master


# client/sub/gui
# client/AcademiaApp/AcademiaGui
cd /opt/chorke/academia/client/AcademiaApp/AcademiaGui/
cd /opt/chorke/academia/client/AcademiaApp/AcademiaGui/
git pull origin master
git pull origin master; cd ..
cd ..


# client/app
# academia/client/AcademiaApp
git status
git add AcademiaGui; git commit -m 'AcademiaGui updated'
git add AcademiaGui
git commit -m 'AcademiaGui updated'
git push origin master
git push origin master


# master/gui
# academia/master/AcademiaApp
cd /opt/chorke/academia/master/AcademiaApp/
cd /opt/chorke/academia/master/AcademiaApp/
git submodule foreach git pull origin master
git submodule foreach git pull origin master
git pull origin master
git pull origin master
</source>
</source>
==Rename==
<source lang="bash" highlight="6,7,10">
git clone /opt/chorke/academia/server/agronomy-apps-ckiapp.git AgronomyApp
git clone /opt/chorke/academia/server/agronomy-apps-ckiapi.git AgronomyApi
git clone /opt/chorke/academia/server/agronomy-apps-ckigui.git AgronomyGui
cd AgronomyApp
git mv AcademiaApi AgronomyApi
git mv AcademiaGui AgronomyGui
# update modules
vim .gitmodules
</source>
==Knowledge==
git submodule init
git submodule update
git config --global init.defaultBranch master
==References==
* [https://stackoverflow.com/questions/17195861 Undo <code>git update-index --assume-unchanged</code>]
* [https://stackoverflow.com/questions/1777854 Specify a branch/tag when adding a Git submodule]
* [https://stackoverflow.com/questions/5542910 Commit changes in a git submodule]
* [https://cdn.chorke.org/goto/watch?v=CRlGDDprdOQ Git Merge vs Rbase] <code>YouTube</code>
* [https://git-scm.com/book/en/v2/Git-Tools-Advanced-Merging#_subtree_merge Git Tools Advanced Merging]
* [https://stackoverflow.com/questions/4526910/ Git Rename a Submodule]
* [https://git-scm.com/book/en/v2/Git-Tools-Submodules Git Tools Submodules]
* [[GitLab]]
* [[Git]]

Latest revision as of 01:54, 13 March 2023

Git submodule is very simple where you have to aware about few things. Those are as following:

1. After addition of submodule, you have commit main module must
2. After pull of submodule, you have to pull/commit main module
3. After commit of submodule, you have to commit main module

Structure

:'
/opt/chorke/academia
  ├─ master
  │  ├─ AcademiaApi
  │  ├─ AcademiaGui
  │  └─ AcademiaApp
  ├─ server
  │  ├─ academia-apps-ckiapi.git
  │  ├─ academia-apps-ckigui.git
  │  └─ academia-apps-ckiapp.git
  └─ client
     ├─ AcademiaApi
     ├─ AcademiaGui
     └─ AcademiaApp
'
cd /opt/chorke/academia/server/
git init --bare academia-apps-ckiapi.git
git init --bare academia-apps-ckigui.git
git init --bare academia-apps-ckiapp.git

Master

:'
/opt/chorke/academia/master/AcademiaApi
   ├─ .gitignore
   ├─ README.md
   └─ LICENSE
'
cd /opt/chorke/academia/master/AcademiaApi;git init
git remote add origin /opt/chorke/academia/server/academia-apps-ckiapi.git
git add --all; git commit -m 'initial commit'; git push origin master
:'
/opt/chorke/academia/master/AcademiaGui
   ├─ .gitignore
   ├─ README.md
   └─ LICENSE
'
cd /opt/chorke/academia/master/AcademiaGui;git init
git remote add origin /opt/chorke/academia/server/academia-apps-ckigui.git
git add --all; git commit -m 'initial commit'; git push origin master
:'
/opt/chorke/academia/master/AcademiaApp
   ├─ .gitignore
   ├─ README.md
   └─ LICENSE
'
cd /opt/chorke/academia/master/AcademiaApp;git init
git remote add origin /opt/chorke/academia/server/academia-apps-ckiapp.git
git add --all; git commit -m 'initial commit'; git push origin master
:'
git submodule add /opt/chorke/academia/server/academia-apps-ckiapi.git
git submodule add /opt/chorke/academia/server/academia-apps-ckigui.git

git rm --cached academia-apps-ckiapi; git rm --cached academia-apps-ckigui
git rm --cached .gitmodules; git reset --hard; git clean -fd
rm -rf academia-apps-cki*
'

git submodule add /opt/chorke/academia/server/academia-apps-ckiapi.git AcademiaApi
git submodule add /opt/chorke/academia/server/academia-apps-ckigui.git AcademiaGui

git config -f .gitmodules submodule.AcademiaApi.branch master
git config -f .gitmodules submodule.AcademiaGui.branch master

git commit -m 'academia-ruap-{ckiapi,ckigui} added'
git push origin master

Client

# academia/client/AcademiaApp
cd /opt/chorke/academia/client/
git clone /opt/chorke/academia/server/academia-apps-ckiapp.git AcademiaApp
# cd AcademiaApp; git submodule init; git submodule update
cd AcademiaApp; git submodule update --init

vim HelloApp.txt;git add HelloApp.txt
git commit -m 'Hello App Added'

Wrong

# client/AcademiaApp/AcademiaGui
cd /opt/chorke/academia/client/AcademiaApp/AcademiaGui/
vim HelloGui.txt; git add HelloGui.txt
git commit -m 'Hello Gui Added'
git status; cd ..; git status

# academia/client/AcademiaApp
git submodule status --recursive
git submodule foreach git pull origin master
git submodule foreach git push -u origin master

# academia/master/AcademiaGui
cd /opt/chorke/academia/master/AcademiaGui/
git pull origin master

Right

# client/AcademiaApp/AcademiaGui
cd /opt/chorke/academia/client/AcademiaApp/AcademiaGui/
git checkout master; vim HelloGui.txt; git add HelloGui.txt
git commit -m 'Hello GUI Added'
git push origin master; cd ..

# academia/client/AcademiaApp
git add AcademiaGui; git commit -m 'AcademiaGui updated'
git push origin master

# academia/master/AcademiaGui
cd /opt/chorke/academia/master/AcademiaGui/
vim HelloAdd.txt; git add HelloAdd.txt
git commit -m 'Hello Add Text File Added'
git push origin master

# client/AcademiaApp/AcademiaGui
cd /opt/chorke/academia/client/AcademiaApp/AcademiaGui/
git pull origin master; cd ..

# academia/client/AcademiaApp
git add AcademiaGui; git commit -m 'AcademiaGui updated'
git push origin master

# academia/master/AcademiaApp
cd /opt/chorke/academia/master/AcademiaApp/
git submodule foreach git pull origin master
git pull origin master

Rename

git clone /opt/chorke/academia/server/agronomy-apps-ckiapp.git AgronomyApp
git clone /opt/chorke/academia/server/agronomy-apps-ckiapi.git AgronomyApi
git clone /opt/chorke/academia/server/agronomy-apps-ckigui.git AgronomyGui

cd AgronomyApp
git mv AcademiaApi AgronomyApi
git mv AcademiaGui AgronomyGui

# update modules
vim .gitmodules

Knowledge

git submodule init
git submodule update
git config --global init.defaultBranch master

References