Open all files from a git diff or git show with this handy command utility
Sun, Dec 25, 2011
We use git as our versioning tool at work and I've gradually been learning a few tricks on how to speed up my development time and time spent managing my repo.
When jumping between branches, continuing your work from where you stopped last time, etc., you very often open the same files as you were editing in a previous commit. This may not be a problem if you use something like Command-T for vim or rely on the file browsing in TextMate, but often it might just be quicker to open all the files from a particular ref in git or opening all files from your branch's diff from master/dev or something.
I made this little snippet of a shell script that allows you to open all files from a git diff or show command in one fell swoop. Usage goes something like:
orgitopen diff master
or simplygitopen show 3663c033
The command takes two arguments:gitopen
Where ref could be a hash or a branch name etc.gitopen [diff <ref>] [show <ref>]
If you want to try it, you can download it here: https://gist.github.com/gists/1517095/download
Paul Rosnia also made a change which makes the script try to use the $EDITOR environment variable if it exists. You can override that if you like to use a different editor than is set by your environment.
If you find this utility useful, please let me know in the comments.
Update: Jarin Udom pointed out to me on Hacker News the following:
If you add a git alias, like so:
It will allow you to use the command like other git commands:git config --global alias.open '!sh ~/gitopen.sh'
Apparently you should also be able to name the file git-open somewhere in your path, and that should have the same effect. However, it did not work for me and I have no idea why, but the git global config variable worked great.git open diff master