How to do upgrade Git in Mac OS X?

upgrade git in mac os xGit SCM does not comes out-of-the-box(OOTB) with Mac OS X.  However if you have installed Xcode  command line tools or standalone Git Installer then you will have Git SCM on Mac OS X.


Warm Up!

Let’s check existing Git version on your machine.

Scenario 1: You will get similar to this version!

mac-book-pro:~ jeeva$ git --version

git version 1.7.7.5 (Apple Git-26)

OR

Scenario 2: you may get like this

If you get below message nothing to worry; it means you have not yet installed Git SCM on your machine

mac-book-pro:~ jeeva$ git --version

-bash: git: command not found

Let’s start Git upgrade

First thing, get the latest Git SCM for Mac OS X Click here to Download(from git-scm.com).  You will get .dmg file.  In this article I’m using current latest version of Git SCM 1.7.11.3 for upgrade!

  • Open the downloaded git-x.x.x.x-intel-universal-snow-leopard.dmg
  • You will see uninstall.sh, Run this shell script (if you have scenario 2 on your machine, skip this step)
  • Run the git-x.x.x.x-intel-universal-snow-leopard.pkg installer and follow the installer instruction
    • This installs the Git in /usr/local/git (root access is required)

Once you finished the package execution (after, click of ‘Finish‘ button)


Git Upgrade Verification

Restart your bash session.  If you wish to preserve your precious screen session, just execute source /etc/profile.  Verifying Git version

mac-book-pro:~ jeeva$ git --version

git version 1.7.11.3

Wow, you successfully completed upgrade Git in Mac OS X :)

How to handle if I still getting Git old version displayed on my Terminal.  I know it may happen, don’t worry I will explain.  Follow below instructions.

Adding PATH variable to .bash_profile; open up Terminal.app

mac-book-pro:~ jeeva$ vim ~/.bash_profile

Place the below export statement at the end of .bash_profile

export PATH=/usr/local/git/bin:$PATH

Save your modified .bash_profile and close the vim editor.  Either close and re-open your Terminal or execute below command

mac-book-pro:~ jeeva$ . ~/.bash_profile
Executing Terminal bash profile...

mac-book-pro:~ jeeva$

Now verify Git version and you’re good to go :)


Git for Non-terminal programs (Optional Step/Instruction for you)

Typically Non-terminal programs don’t inherit the system wide PATH and MANPATH variables that your terminal does.  If you’d like them to be able to see latest Git for any reason.

Run this shell ‘setup git PATH for non-terminal programs.sh‘ from the downloaded .dmg installer

mac-book-pro:~ jeeva$ /bin/sh "/Volumes/Git 1.7.11.3 Snow Leopard Intel Universal/setup git PATH for non-terminal programs.sh"

2012-07-28 14:03:57.593 defaults[5177:707]
The domain/default pair of (/Users/jeeva/.MacOSX/environment, PATH) does not exist
Variable PATH in ~/.MacOSX/environment.plist changed from '/usr/bin:/bin:/usr/sbin:/sbin:/usr/local/bin:/usr/X11/bin:/opt/local/bin' to '/usr/bin:/bin:/usr/sbin:/sbin:/usr/local/bin:/usr/X11/bin:/opt/local/bin:/usr/local/git/bin'

You will need to log out of your Mac OS X user account and log back in for changes to take effect.
~ ~
~

mac-book-pro:~ jeeva$

Above script will add the PATH and MANPATH to your ~/.MacOSX/environment.plist file.

You’ll need to log out of your user account for that to take effect.