The git submodule feature allows you to embed one git repository inside another.
When a git submodule is added, the files contained with the submodule have special treatment inside the parent repository. The parent repository does not commit the individual files, but rather just saves the current commit SHA1 that is checked-out with the submodule.
To add a new submodule:
$ git submodule add email@example.com:projectname lib/projectname
With newer version of git, the above add command will also clone the submodule files into the directory.
But if you don’t have the files yet, run:
$ git submodule init
$ git submodule update
git submodules can be used for file management and version lockdown of external dependencies.
Note that when using C++, it may be better to use the CMake ExternalProject_Add() and find_package() API (if available), rather than to rely on git submodules for version lockdown of external dependencies.
Changing An Existing Submodule
Sometimes you may wish to change an existing submodule to point to a completely different remote repo.
- Change the URL in .gitmodules.
- Delete the relevant entry in .git/config.
- Delete the relevant folder in .git/modules. The actual submodule folder will have the same path in .git/modules as it does in your repo, e.g. if your submodule is at /lib/mysubmodule then delete the folder at .git/modules/lib/mysubmodule.
- Delete the submodule (e.g. delete lib/mysubmodule).
git submodule init then
git submodule update. Note, you may get an error similar to:
C1fatal: reference is not a tree: a094dcfeeb43...
when trying to run git submodule update. Don’t worry, this just means it can’t find the old commit SHA1 in your changed submodule. All you have to do to fix this is navigate to the submodule folder, and run git checkout <valid SHA1 here>.
- All done! Don’t for get to commit your changes.
Posted: January 20th, 2017 at 10:50 pm
Last Updated on: December 12th, 2017 at 9:26 am