Always prune remote-tracking branches
— April 20, 2014
tl;dr after version 1.8.5 of git, you can now configure it to automatically prune remote-tracking branches with every fetch/pull.
Before Git version 1.8.5 if you wanted to prune remote-tracking branches you
where forced to use/remember the git fetch --prune command, even if your
workflow didn’t involve fetching directly with the fetch command. For that
reason if you find yourself pulling and then using an alias or just typing git fetch --prune every once in a while, this new Git configuration is perfect for
you.
There are two new configuration commands that will help you achieve this behavior (pruning) in different ways. The first command is:
$ git config fetch.prune true
This command will set in your configuration file the prune flag true, so it will
prune automatically with every fetch. The default git behavior of this flag is
false. Yes, if you’re wondering git pull will implicitly use this flag.
For the last couple of weeks I’ve been giving this a try and it has been a dream
come true, it’s a perfect addition to my workflow (I’m also using the rebase
flag with every pull).
Check out this output:
$ git pull
From github.com:albertogg/test-something
 x [deleted]         (none)     -> origin/fix-bleh
 x [deleted]         (none)     -> origin/fix-something
 x [deleted]         (none)     -> origin/add-gravatar
remote: Counting objects: 5, done.
remote: Compressing objects: 100% (5/5), done.
remote: Total 5 (delta 1), reused 0 (delta 0)
Unpacking objects: 100% (5/5), done.
   def27ef..5596684  master     -> origin/master
First, rewinding head to replay your work on top of it...
Fast-forwarded master to 5596684fbd39d037e1a60a8b75f250d059c3e904.
The second command is somewhat similar to the first one, but it will only apply to the remote repo you want e.g. origin.
$ git config remote.origin.prune true
The results in both cases will be the same; you have to decide which one suites you better, although if you add both configurations to your repo or system wide the second one will overwrite the behavior of the first one, so be careful with that.
Remember, that you can make this configurations work system wide by just adding
the --global flag when executing the command e.g. git config --global fetch.prune true.
Thanks for reading!