List of useful commands to work with submodules.
Add submodule
git submodule add https://github.com/*user*/*repo* path/to/submodule/directory
For using private repository as a submodule:
git submodule add [email protected]:*user*/*repo*.git path/to/submodule/directory
Example
git submodule add https://github.com/codex-team/editor.js editorjs
You will see changes in .gitmodules
file and submodule's directory. Commit changes in both files.
data:image/s3,"s3://crabby-images/d4fc2/d4fc299f845a060a2bf45296935e3095af26dbb1" alt=""
Init submodules
After cloning a repository with submodules you need to initialize them. Otherwise you will see empty directories in submodules places.
Git will download submodules recursively.
git submodule update --init --recursive
Pull updates
Pull submodules by commited state.
git submodule update --recursive
Get the latest updates for remote branches
git submodule update --recursive --remote
Remove submodule
1. Delete the relevant section from the .gitmodules file.
-[submodule "editorjs"]
- path = editorjs
- url = https://github.com/codex-team/editor.js
data:image/s3,"s3://crabby-images/ab08e/ab08e70b5c130b6ea29e1eb68e403dd3eb1a5037" alt=""
2. Stage the .gitmodules
changes: git add .gitmodules
.
3. Delete the relevant section from .git/config
.
[core]
repositoryformatversion = 0
filemode = true
bare = false
logallrefupdates = true
ignorecase = true
precomposeunicode = true
[remote "origin"]
url = https://github.com/talyguryn/test
fetch = +refs/heads/*:refs/remotes/origin/*
[branch "master"]
remote = origin
merge = refs/heads/master
-[submodule "editorjs"]
- active = true
- url = https://github.com/codex-team/editor.js
4. Run git rm --cached path_to_submodule
(no trailing slash).
data:image/s3,"s3://crabby-images/3d13b/3d13bf6bcc00d5c0e70804c808ab8be16cb5e800" alt=""
5. Run rm -rf .git/modules/path_to_submodule
(no trailing slash).
data:image/s3,"s3://crabby-images/293e5/293e52ed0b68ea13dda71e824ad82ece7e9474c1" alt=""
6. Delete the now untracked submodule files rm -rf path_to_submodule
.
7. Commit changes: git commit -am "Remove submodule"
.
Working with submodules
You can work with any submodule via your git client (as a regular repository).
For example. Any changes inside submodule will be shown as dirty
state.
data:image/s3,"s3://crabby-images/d6b27/d6b271ac6b68790bad1072f6bf2f5d3c4f486f13" alt=""
Add submodule's directory as a local repository.
data:image/s3,"s3://crabby-images/210ea/210ea42f178c6f8936816283cf01079ac7bd3407" alt=""
And you will see changes, commit them and checkout branches.
data:image/s3,"s3://crabby-images/ee8e1/ee8e11ad8b48983e18a97a3c3ccb720c99603633" alt=""