2012-05-22 00:18:30 +00:00
|
|
|
Oh My Zsh
|
|
|
|
=========
|
2011-07-18 04:00:35 +00:00
|
|
|
|
2012-05-22 00:18:30 +00:00
|
|
|
OMZ is a configuration framework for [Zsh][1] that enriches the command line
|
|
|
|
interface environment with sane defaults, aliases, functions, auto completion,
|
|
|
|
and prompt themes.
|
2011-07-18 04:00:35 +00:00
|
|
|
|
2012-05-22 00:18:30 +00:00
|
|
|
Installation
|
|
|
|
------------
|
2011-07-18 04:00:35 +00:00
|
|
|
|
2011-12-30 03:55:45 +00:00
|
|
|
Oh My Zsh will work with any recent release of Zsh, but the minimum recommended
|
|
|
|
version is 4.3.10.
|
2011-07-18 04:00:35 +00:00
|
|
|
|
2012-05-22 00:18:30 +00:00
|
|
|
1. Clone the repository:
|
2011-07-18 04:00:35 +00:00
|
|
|
|
2012-05-22 00:18:30 +00:00
|
|
|
`git clone https://github.com/sorin-ionescu/oh-my-zsh.git ~/.oh-my-zsh`
|
2011-07-18 04:00:35 +00:00
|
|
|
|
2012-05-22 00:18:30 +00:00
|
|
|
2. Initialize the submodules:
|
2012-01-28 22:57:03 +00:00
|
|
|
|
2012-05-22 00:18:30 +00:00
|
|
|
`cd ~/.oh-my-zsh && git submodule update --init --recursive`
|
2012-01-28 22:57:03 +00:00
|
|
|
|
2012-05-22 00:18:30 +00:00
|
|
|
3. Create a new Zsh configuration by copying the Zsh template provided:
|
2011-07-18 04:00:35 +00:00
|
|
|
|
2012-05-22 00:18:30 +00:00
|
|
|
`cp ~/.oh-my-zsh/templates/zshrc ~/.zshrc`
|
2011-07-18 04:00:35 +00:00
|
|
|
|
2012-05-22 00:18:30 +00:00
|
|
|
4. Set Zsh as your default shell:
|
2011-07-18 04:00:35 +00:00
|
|
|
|
2012-05-22 00:18:30 +00:00
|
|
|
`chsh -s /bin/zsh`
|
2011-07-18 04:00:35 +00:00
|
|
|
|
2012-05-22 00:18:30 +00:00
|
|
|
5. Open a new Zsh terminal window or tab.
|
2011-12-30 03:55:45 +00:00
|
|
|
|
|
|
|
### Mac OS X
|
|
|
|
|
2012-05-23 19:18:17 +00:00
|
|
|
If you have administrator privileges, you must fix an Apple-introduced problem
|
|
|
|
in Mac OS X 10.5 Leopard by executing the following command, or BASH and Zsh
|
|
|
|
will have the wrong `PATH` when executed non-interactively.
|
|
|
|
|
|
|
|
sudo chmod ugo-x /usr/libexec/path_helper
|
|
|
|
|
|
|
|
`path_helper` is intended to make it easier for installers to add new paths to
|
|
|
|
the environment without having to edit shell configuration files by adding
|
|
|
|
a file with a path to the */etc/paths.d* directory.
|
|
|
|
|
|
|
|
Unfortunately, `path_helper` always reads paths from */etc/paths* set by Apple
|
|
|
|
then paths from */etc/paths.d* set by third party installers, and lastly paths
|
|
|
|
from the `PATH` environment variable set by the parent process, which
|
|
|
|
ultimately is set by the user with `export PATH=...` Thus, it reorders path
|
|
|
|
priorities, and user */bin* directories meant to override system */bin*
|
|
|
|
directories end up at the tail of the array.
|
2011-07-18 04:00:35 +00:00
|
|
|
|
2011-12-30 03:55:45 +00:00
|
|
|
### Troubleshooting
|
2011-07-18 04:00:35 +00:00
|
|
|
|
2011-12-30 03:55:45 +00:00
|
|
|
If you are not able to find certain commands after switching to *Oh My Zsh*,
|
2012-05-23 19:18:17 +00:00
|
|
|
modify the `PATH` variable in *environment.zsh* then open a new Zsh terminal
|
2011-12-30 03:55:45 +00:00
|
|
|
window or tab.
|
2011-07-18 04:00:35 +00:00
|
|
|
|
|
|
|
## Usage
|
|
|
|
|
2011-12-30 03:55:45 +00:00
|
|
|
Oh My Zsh has many features disabled by default. Read the source code and
|
|
|
|
accompanying README files to learn of what is available.
|
2011-07-18 04:00:35 +00:00
|
|
|
|
2012-03-28 16:41:39 +00:00
|
|
|
### Modules
|
2011-07-18 04:00:35 +00:00
|
|
|
|
2012-05-23 19:18:17 +00:00
|
|
|
1. Browse */modules* to see what is available.
|
|
|
|
2. Load the modules you need in *~/.zshrc* then open a new Zsh terminal
|
2012-05-22 00:18:30 +00:00
|
|
|
window or tab.
|
2011-07-18 04:00:35 +00:00
|
|
|
|
2011-12-30 03:55:45 +00:00
|
|
|
### Themes
|
2011-07-18 04:00:35 +00:00
|
|
|
|
2012-05-22 00:18:30 +00:00
|
|
|
1. For a list of themes, type `prompt -l`.
|
|
|
|
2. To preview a theme, type `prompt -p name`.
|
2012-05-23 19:18:17 +00:00
|
|
|
3. Load the theme you like in *~/.zshrc* then open a new Zsh terminal window
|
2012-05-22 00:18:30 +00:00
|
|
|
or tab.
|
|
|
|
![sorin theme][2]
|
2011-07-18 04:00:35 +00:00
|
|
|
|
2012-01-28 22:57:03 +00:00
|
|
|
## Customization
|
2011-07-18 04:00:35 +00:00
|
|
|
|
2012-05-22 00:18:30 +00:00
|
|
|
The project is managed via [Git][3]. It is highly recommend that you commit
|
|
|
|
your changes and push them to [GitHub][4] to not lose them. If you do not know
|
|
|
|
how to use Git, follow this [tutorial][5] and bookmark this [reference][6].
|
2011-07-18 04:00:35 +00:00
|
|
|
|
2012-01-28 22:57:03 +00:00
|
|
|
### Completions
|
|
|
|
|
2012-05-22 00:18:30 +00:00
|
|
|
Submit program completions to the [zsh-completions][7] project. The Oh My Zsh
|
|
|
|
completions directory will be synched against it.
|
2012-01-28 22:57:03 +00:00
|
|
|
|
2011-12-30 03:55:45 +00:00
|
|
|
## Resources
|
2011-07-18 04:00:35 +00:00
|
|
|
|
2012-05-22 00:18:30 +00:00
|
|
|
The [Zsh Reference Card][8] is indispensable.
|
2011-07-18 04:00:35 +00:00
|
|
|
|
2011-12-30 03:55:45 +00:00
|
|
|
## Contribute
|
2011-07-18 04:00:35 +00:00
|
|
|
|
2012-05-22 00:18:30 +00:00
|
|
|
This project would not exist without all of its users and [contributors][9].
|
2011-07-18 04:00:35 +00:00
|
|
|
|
2011-12-30 03:55:45 +00:00
|
|
|
If you have ideas on how to make the configuration easier to maintain or
|
|
|
|
improve its performance, do not hesitate to fork and send pull requests.
|
2011-07-18 04:00:35 +00:00
|
|
|
|
2011-12-28 22:04:43 +00:00
|
|
|
## License
|
|
|
|
|
|
|
|
(The MIT License)
|
|
|
|
|
2012-01-26 16:59:36 +00:00
|
|
|
Copyright (c) 2009-2012 Robby Russell, Sorin Ionescu, and contributors.
|
2011-12-28 22:04:43 +00:00
|
|
|
|
2011-12-30 03:55:45 +00:00
|
|
|
Permission is hereby granted, free of charge, to any person obtaining a copy of
|
|
|
|
this software and associated documentation files (the "Software"), to deal in
|
|
|
|
the Software without restriction, including without limitation the rights to
|
|
|
|
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
|
|
|
|
of the Software, and to permit persons to whom the Software is furnished to do
|
|
|
|
so, subject to the following conditions:
|
|
|
|
|
|
|
|
The above copyright notice and this permission notice shall be included in all
|
|
|
|
copies or substantial portions of the Software.
|
|
|
|
|
|
|
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
|
|
SOFTWARE.
|
2011-12-28 22:04:43 +00:00
|
|
|
|
2012-05-22 00:18:30 +00:00
|
|
|
[1]: http://www.zsh.org
|
|
|
|
[2]: http://i.imgur.com/aipDQ.png "sorin theme"
|
|
|
|
[3]: http://git-scm.com
|
|
|
|
[4]: https://github.com
|
|
|
|
[5]: http://gitimmersion.com
|
|
|
|
[6]: http://gitref.org
|
|
|
|
[7]: https://github.com/zsh-users/zsh-completions
|
|
|
|
[8]: http://www.bash2zsh.com/zsh_refcard/refcard.pdf
|
|
|
|
[9]: https://github.com/sorin-ionescu/oh-my-zsh/contributors
|
|
|
|
|