Skip to content

Instantly share code, notes, and snippets.

@mjsteinbaugh
Forked from slavafomin/git-submodules.md
Created April 1, 2019 21:47
Show Gist options
  • Save mjsteinbaugh/c91dfd8659c20be6220c1d65df1dcbc6 to your computer and use it in GitHub Desktop.
Save mjsteinbaugh/c91dfd8659c20be6220c1d65df1dcbc6 to your computer and use it in GitHub Desktop.
Git submodules best practices

Git submodules best practices

Useful commands

— Clone repository with submodules automatically:

git clone --recursive [email protected]:name/repo.git

— Initialize submodules after regular cloning:

git submodule update --init

— Make submodules to track their respective remote branches (instead of being in detached HEAD state):

git submodule foreach -q --recursive 'git checkout $(git config -f $toplevel/.gitmodules submodule.$name.branch || echo master)'

— Display status of submodules when git status is invoked:

git config --global status.submoduleSummary true

— Script for pulling the main repo and updating the sumodules automatically:

#!/usr/bin/env bash

git pull "$@" &&
  git submodule sync --recursive &&
  git submodule update --init --recursive

Additional reading

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment