Skip to content


Subversion checkout URL

You can clone with
Download ZIP
A community-driven framework for managing your zsh configuration. Includes optional plugins for various tools (rails, git, OSX, brew,...), nearly 70 terminal themes, and an auto-updating tool so that you can keep up with the latest improvements from the community.
Branch: master
Pull request Compare This branch is 3195 commits behind robbyrussell:master.
Failed to load latest commit information.
custom Moving some example files into custom/
lib Revert "Enable alias completion, do not limit completion to just files"
log Adding a file into log/ so that we have a log file to record history to
plugins changes recommended by blueyed
templates Introduce DISABLE_AUTO_TITLE option
themes support non-standard rvm install prefixes
tools Fixed auto update.
.gitignore Made git ignore everything in custom, not only the .zsh files.
README.textile Postponing sourcing of the theme until after local customizations


A handful of functions, auto-complete helpers, and stuff that makes you shout…



oh-my-zsh should work with any recent release of zsh, the minimum recommended version is 4.3.9.

The automatic installer… (do you trust me?)

wget --no-check-certificate -O - | sh

The manual way

1. Clone the repository

git clone git:// ~/.oh-my-zsh

2. Create a new zsh config by copying the zsh template we’ve provided.

NOTE: If you already have a ~/.zshrc file, you should back it up. cp ~/.zshrc ~/.zshrc.orig in case you want to go back to your original settings. cp ~/.oh-my-zsh/templates/zshrc.zsh-template ~/.zshrc

3. Set zsh as your default shell:

chsh -s /bin/zsh

4. Start / restart zsh (open a new terminal is easy enough…)


You might need to modify your PATH in ~/.zshrc if you’re not able to find some commands after switching to Oh My Zsh.


  • enable the plugins you want in your ~/.zshrc (take a look at plugins/ to see what’s possible)
    • example: plugins=(git osx ruby)
  • Theme support: Change the ZSH_THEME environment variable in ~/.zshrc.
  • much much more… take a look at lib/ what Oh My Zsh offers…


the refcard is pretty tasty for tips.


If you want to override any of the default behavior, just add a new file (ending in .zsh) into the custom/ directory.
If you have many functions which go good together you can put them as a *.plugin.zsh file in the plugin/ directory and then enable this plugin.


If you want to uninstall it, just run uninstall_oh_my_zsh from the command line and it’ll remove itself and revert you to bash (or your previous zsh config).

Help out!

I’m far from being a zsh-expert and suspect there are many ways to improve. If you have ideas on how to make the configuration easier to maintain (and faster), don’t hesitate to fork and send pull requests!

Send us your theme!

I’m hoping to collect a bunch of themes for our command prompts. You can see existing ones in the themes/ directory.


This project wouldn’t exist without all of our awesome users and contributors.

Thank you so much!

Something went wrong with that request. Please try again.