Git is a very powerful source control system. There are some useful commands to try and memorise!
Get the location of the config files used for all the settings in git
git config --list --show-origin
Set your user info
git config --global user.email "email@example.com"git config --global user.name "Sample Name"
Add a global proxy for your setup
git config --global http.proxy "http://account:password@proxy:port"
Add a proxy for a given URL:
git config --global http.fullsitename.proxy "http://account:password@proxy:port"
A sample of the above:
git config --global http.https://dev.azure.com.proxy "http://mattcorr:firstname.lastname@example.org:8080"
Generally speaking, avoid submodules and use nuget packages instead. But if you have to deal with them, when you pull a full repo, it is likely you will need to update all the submodules as well. This can be done with running from the repo root:
git submodule foreach git pull origin master
Undo a commit to a local branch. Say you accidently push files to your local master instead of pushing to a branch for a PR, use this to undo the change:
git reset --soft HEAD~1
This will undo the commit AND leave the changed files still changed so you can push them to the correct branch. But if you want to blow away the changes and revert to the previous commit just use:
git reset --hard HEAD~1
But be really sure you want to do it as there is no undo.