At TODO we design and develop a big variety of projects.
Sometimes those projects rely on interactive software for exhibits. This means developing several software belonging to the same project and each software needs share/use some common parts. For that reason we usually put all the source code on a single git repository for convenience.
The downside of this choice is that by deploying the same repository on different machines, every time we run
git pull to update the software it will download all the repository history with all the files related to the whole project. This is not very efficient nor bandwidth saver.
Luckily enough, git comes with a very handy command to let us save time and bandwidth by allowing to checkout a portion of a repository. The whole command is
sparsecheckout and here is the gist about its setup:
git init myRepo
git remote add origin <repo url>
git config core.sparsecheckout true
echo "some/dir/" >> .git/info/sparse-checkout
git pull --depth=1 origin master
PS: each folder needs to be present in the remote repository to check it properly out.
Spotted a typo or (likely) a grammar error? Send a pull request.