mirror of
https://github.com/ohmyzsh/ohmyzsh.git
synced 2024-12-12 20:21:02 +01:00
Merge branch 'master' of github.com:robbyrussell/oh-my-zsh
This commit is contained in:
commit
7b0b83623f
20 changed files with 223 additions and 25 deletions
1
.gitignore
vendored
1
.gitignore
vendored
|
@ -2,5 +2,6 @@ locals.zsh
|
||||||
log/.zsh_history
|
log/.zsh_history
|
||||||
projects.zsh
|
projects.zsh
|
||||||
custom/*
|
custom/*
|
||||||
|
!custom/example
|
||||||
!custom/example.zsh
|
!custom/example.zsh
|
||||||
cache
|
cache
|
||||||
|
|
|
@ -48,7 +48,9 @@ the "refcard":http://www.bash2zsh.com/zsh_refcard/refcard.pdf is pretty tasty fo
|
||||||
h3. Customization
|
h3. Customization
|
||||||
|
|
||||||
If you want to override any of the default behavior, just add a new file (ending in @.zsh@) into the @custom/@ directory.
|
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 have many functions which go good together you can put them as a *.plugin.zsh file in the @custom/plugins/@ directory and then enable this plugin.
|
||||||
|
If you would like to override the functionality of a plugin distributed with oh-my-zsh, create a plugin of the same name in the @custom/plugins/@ directory and it will be loaded instead of the one in @plugins/@.
|
||||||
|
|
||||||
|
|
||||||
h3. Uninstalling
|
h3. Uninstalling
|
||||||
|
|
||||||
|
|
2
custom/example/example.plugin.zsh
Normal file
2
custom/example/example.plugin.zsh
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
# Add your own custom plugins in the custom/plugins directory. Plugins placed
|
||||||
|
# here will override ones with the same name in the main plugins directory.
|
|
@ -17,7 +17,9 @@ compinit -i
|
||||||
|
|
||||||
# Load all of the plugins that were defined in ~/.zshrc
|
# Load all of the plugins that were defined in ~/.zshrc
|
||||||
for plugin ($plugins); do
|
for plugin ($plugins); do
|
||||||
if [ -f $ZSH/plugins/$plugin/$plugin.plugin.zsh ]; then
|
if [ -f $ZSH/custom/plugins/$plugin/$plugin.plugin.zsh ]; then
|
||||||
|
source $ZSH/custom/plugins/$plugin/$plugin.plugin.zsh
|
||||||
|
elif [ -f $ZSH/plugins/$plugin/$plugin.plugin.zsh ]; then
|
||||||
source $ZSH/plugins/$plugin/$plugin.plugin.zsh
|
source $ZSH/plugins/$plugin/$plugin.plugin.zsh
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
|
@ -1,8 +1,15 @@
|
||||||
|
stat -f%m . > /dev/null 2>&1
|
||||||
|
if [ "$?" = 0 ]; then
|
||||||
|
stat_cmd=(stat -f%m)
|
||||||
|
else
|
||||||
|
stat_cmd=(stat -L --format=%y)
|
||||||
|
fi
|
||||||
|
|
||||||
_ant_does_target_list_need_generating () {
|
_ant_does_target_list_need_generating () {
|
||||||
if [ ! -f .ant_targets ]; then return 0;
|
if [ ! -f .ant_targets ]; then return 0;
|
||||||
else
|
else
|
||||||
accurate=$(stat -f%m .ant_targets)
|
accurate=$($stat_cmd -f%m .ant_targets)
|
||||||
changed=$(stat -f%m build.xml)
|
changed=$($stat_cmd -f%m build.xml)
|
||||||
return $(expr $accurate '>=' $changed)
|
return $(expr $accurate '>=' $changed)
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,10 +25,12 @@ _1st_arguments=(
|
||||||
'link:link a formula'
|
'link:link a formula'
|
||||||
'list:list files in a formula or not-installed formulae'
|
'list:list files in a formula or not-installed formulae'
|
||||||
'log:git commit log for a formula'
|
'log:git commit log for a formula'
|
||||||
|
'missing:check all installed formuale for missing dependencies.'
|
||||||
'outdated:list formulas for which a newer version is available'
|
'outdated:list formulas for which a newer version is available'
|
||||||
'prune:remove dead links'
|
'prune:remove dead links'
|
||||||
'remove:remove a formula'
|
'remove:remove a formula'
|
||||||
'search:search for a formula (/regex/ or string)'
|
'search:search for a formula (/regex/ or string)'
|
||||||
|
'server:start a local web app that lets you browse formulae (requires Sinatra)'
|
||||||
'unlink:unlink a formula'
|
'unlink:unlink a formula'
|
||||||
'update:freshen up links'
|
'update:freshen up links'
|
||||||
'upgrade:upgrade outdated formulae'
|
'upgrade:upgrade outdated formulae'
|
||||||
|
@ -36,10 +38,14 @@ _1st_arguments=(
|
||||||
)
|
)
|
||||||
|
|
||||||
local expl
|
local expl
|
||||||
local -a formula installed_formulae
|
local -a formulae installed_formulae
|
||||||
|
|
||||||
_arguments \
|
_arguments \
|
||||||
'(-v --verbose)'{-v,--verbose}'[verbose]' \
|
'(-v)-v[verbose]' \
|
||||||
|
'(--cellar)--cellar[brew cellar]' \
|
||||||
|
'(--config)--config[brew configuration]' \
|
||||||
|
'(--env)--env[brew environment]' \
|
||||||
|
'(--repository)--repository[brew repository]' \
|
||||||
'(--version)--version[version information]' \
|
'(--version)--version[version information]' \
|
||||||
'(--prefix)--prefix[where brew lives on this system]' \
|
'(--prefix)--prefix[where brew lives on this system]' \
|
||||||
'(--cache)--cache[brew cache]' \
|
'(--cache)--cache[brew cache]' \
|
||||||
|
@ -51,20 +57,24 @@ if (( CURRENT == 1 )); then
|
||||||
fi
|
fi
|
||||||
|
|
||||||
case "$words[1]" in
|
case "$words[1]" in
|
||||||
list)
|
search|-S)
|
||||||
|
_arguments \
|
||||||
|
'(--macports)--macports[search the macports repository]' \
|
||||||
|
'(--fink)--fink[search the fink repository]' ;;
|
||||||
|
list|ls)
|
||||||
_arguments \
|
_arguments \
|
||||||
'(--unbrewed)--unbrewed[files in brew --prefix not controlled by brew]' \
|
'(--unbrewed)--unbrewed[files in brew --prefix not controlled by brew]' \
|
||||||
|
'(--versions)--versions[list all installed versions of a formula]' \
|
||||||
'1: :->forms' && return 0
|
'1: :->forms' && return 0
|
||||||
|
|
||||||
if [[ "$state" == forms ]]; then
|
if [[ "$state" == forms ]]; then
|
||||||
_brew_installed_formulae
|
_brew_installed_formulae
|
||||||
_requested installed_formulae expl 'installed formulae' compadd -a installed_formulae
|
_wanted installed_formulae expl 'installed formulae' compadd -a installed_formulae
|
||||||
fi ;;
|
fi ;;
|
||||||
install|home|log|info|uses|cat|deps)
|
install|home|homepage|log|info|abv|uses|cat|deps|edit|options)
|
||||||
_brew_all_formulae
|
_brew_all_formulae
|
||||||
_wanted formulae expl 'all formulae' compadd -a formulae ;;
|
_wanted formulae expl 'all formulae' compadd -a formulae ;;
|
||||||
remove|edit|xo)
|
remove|rm|uninstall|unlink|cleanup|link|ln)
|
||||||
_brew_installed_formulae
|
_brew_installed_formulae
|
||||||
_wanted installed_formulae expl 'installed formulae' compadd -a installed_formulae ;;
|
_wanted installed_formulae expl 'installed formulae' compadd -a installed_formulae ;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
|
|
1
plugins/brew/brew.plugin.zsh
Normal file
1
plugins/brew/brew.plugin.zsh
Normal file
|
@ -0,0 +1 @@
|
||||||
|
alias brews='brew list -1'
|
|
@ -5,7 +5,6 @@
|
||||||
# VERSION: 1.0.0
|
# VERSION: 1.0.0
|
||||||
# ------------------------------------------------------------------------------
|
# ------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
|
||||||
if (( ${+commands[compleat]} )); then
|
if (( ${+commands[compleat]} )); then
|
||||||
local prefix="${commands[compleat]:h:h}"
|
local prefix="${commands[compleat]:h:h}"
|
||||||
local setup="${prefix}/share/compleat-1.0/compleat_setup"
|
local setup="${prefix}/share/compleat-1.0/compleat_setup"
|
||||||
|
@ -19,4 +18,3 @@ if (( ${+commands[compleat]} )); then
|
||||||
source "$setup"
|
source "$setup"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
|
@ -4,4 +4,3 @@ if [ "$commands[(I)hub]" ]; then
|
||||||
# eval `hub alias -s zsh`
|
# eval `hub alias -s zsh`
|
||||||
function git(){hub "$@"}
|
function git(){hub "$@"}
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
5
plugins/node/node.plugin.zsh
Normal file
5
plugins/node/node.plugin.zsh
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
# Open the node api for your current version to the optional section.
|
||||||
|
# TODO: Make the section part easier to use.
|
||||||
|
function node-docs {
|
||||||
|
open "http://nodejs.org/docs/$(node --version)/api/all.html#$1"
|
||||||
|
}
|
|
@ -1,3 +1,9 @@
|
||||||
|
alias showfiles='defaults write com.apple.finder AppleShowAllFiles TRUE; killall Finder'
|
||||||
|
alias hidefiles='defaults write com.apple.finder AppleShowAllFiles FALSE; killall Finder'
|
||||||
|
|
||||||
|
# Recursively delete .DS_Store files
|
||||||
|
alias rm-dsstore="find . -name '*.DS_Store' -type f -delete"
|
||||||
|
|
||||||
function savepath() {
|
function savepath() {
|
||||||
pwd > ~/.current_path~
|
pwd > ~/.current_path~
|
||||||
}
|
}
|
||||||
|
|
10
plugins/pow/pow.plugin.zsh
Normal file
10
plugins/pow/pow.plugin.zsh
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
# Thanks to Christopher Sexton
|
||||||
|
# https://gist.github.com/965032
|
||||||
|
function kapow {
|
||||||
|
touch ~/.pow/$1/tmp/restart.txt
|
||||||
|
if [ $? -eq 0 ]; then
|
||||||
|
echo "$fg[yellow]Pow restarting $1...$reset_color"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
compctl -W ~/.pow -/ kapow
|
|
@ -1,3 +1,5 @@
|
||||||
|
# TODO: Make this compatible with rvm.
|
||||||
|
# Run sudo gem on the system ruby, not the active ruby.
|
||||||
alias sgem='sudo gem'
|
alias sgem='sudo gem'
|
||||||
|
|
||||||
# Find ruby file
|
# Find ruby file
|
||||||
|
|
|
@ -1,3 +1,44 @@
|
||||||
fpath=($ZSH/plugins/rvm $fpath)
|
alias rubies='rvm list rubies'
|
||||||
autoload -U compinit
|
alias gemsets='rvm gemset list'
|
||||||
compinit -i
|
|
||||||
|
local ruby18='ruby-1.8.7-p334'
|
||||||
|
local ruby19='ruby-1.9.2-p180'
|
||||||
|
|
||||||
|
function rb18 {
|
||||||
|
if [ -z "$1" ]; then
|
||||||
|
rvm use "$ruby18"
|
||||||
|
else
|
||||||
|
rvm use "$ruby18@$1"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
_rb18() {compadd `ls -1 $rvm_path/gems | grep "^$ruby18@" | sed -e "s/^$ruby18@//" | awk '{print $1}'`}
|
||||||
|
compdef _rb18 rb18
|
||||||
|
|
||||||
|
function rb19 {
|
||||||
|
if [ -z "$1" ]; then
|
||||||
|
rvm use "$ruby19"
|
||||||
|
else
|
||||||
|
rvm use "$ruby19@$1"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
_rb19() {compadd `ls -1 $rvm_path/gems | grep "^$ruby19@" | sed -e "s/^$ruby19@//" | awk '{print $1}'`}
|
||||||
|
compdef _rb19 rb19
|
||||||
|
|
||||||
|
function rvm-update {
|
||||||
|
rvm get head
|
||||||
|
rvm reload # TODO: Reload rvm completion?
|
||||||
|
}
|
||||||
|
|
||||||
|
# TODO: Make this usable w/o rvm.
|
||||||
|
function gems {
|
||||||
|
local current_ruby=`rvm-prompt i v p`
|
||||||
|
local current_gemset=`rvm-prompt g`
|
||||||
|
|
||||||
|
gem list $@ | sed \
|
||||||
|
-Ee "s/\([0-9\.]+( .+)?\)/$fg[blue]&$reset_color/g" \
|
||||||
|
-Ee "s|$(echo $rvm_path)|$fg[magenta]\$rvm_path$reset_color|g" \
|
||||||
|
-Ee "s/$current_ruby@global/$fg[yellow]&$reset_color/g" \
|
||||||
|
-Ee "s/$current_ruby$current_gemset$/$fg[green]&$reset_color/g"
|
||||||
|
}
|
||||||
|
|
|
@ -1,11 +1,9 @@
|
||||||
|
|
||||||
# TextMate
|
|
||||||
alias et='mate .'
|
alias et='mate .'
|
||||||
alias ett='mate app config lib db public spec test Rakefile Capfile Todo'
|
alias ett='mate app config lib db public spec test Rakefile Capfile Todo'
|
||||||
alias etp='mate app config lib db public spec test vendor/plugins vendor/gems Rakefile Capfile Todo'
|
alias etp='mate app config lib db public spec test vendor/plugins vendor/gems Rakefile Capfile Todo'
|
||||||
alias etts='mate app config lib db public script spec test vendor/plugins vendor/gems Rakefile Capfile Todo'
|
alias etts='mate app config lib db public script spec test vendor/plugins vendor/gems Rakefile Capfile Todo'
|
||||||
|
|
||||||
# Editor Ruby file in TextMate
|
# Edit Ruby app in TextMate
|
||||||
alias mr='mate CHANGELOG app config db lib public script spec test'
|
alias mr='mate CHANGELOG app config db lib public script spec test'
|
||||||
|
|
||||||
function tm() {
|
function tm() {
|
||||||
|
|
4
plugins/thor/_thor
Normal file
4
plugins/thor/_thor
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
#compdef thor
|
||||||
|
#autoload
|
||||||
|
|
||||||
|
compadd `thor list | grep thor | cut -d " " -f 2`
|
15
themes/minimal.zsh-theme
Normal file
15
themes/minimal.zsh-theme
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
ZSH_THEME_GIT_PROMPT_PREFIX="%{$reset_color%}%{$fg[white]%}["
|
||||||
|
ZSH_THEME_GIT_PROMPT_SUFFIX="]%{$reset_color%}"
|
||||||
|
ZSH_THEME_GIT_PROMPT_DIRTY="%{$fg[red]%}●%{$reset_color%}"
|
||||||
|
ZSH_THEME_GIT_PROMPT_CLEAN=""
|
||||||
|
|
||||||
|
#Customized git status, oh-my-zsh currently does not allow render dirty status before branch
|
||||||
|
git_custom_status() {
|
||||||
|
local cb=$(current_branch)
|
||||||
|
if [ -n "$cb" ]; then
|
||||||
|
echo "- $ZSH_THEME_GIT_PROMPT_PREFIX$(current_branch)$(parse_git_dirty)$ZSH_THEME_GIT_PROMPT_SUFFIX"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
PROMPT='%2~ $(git_custom_status) »%b '
|
95
themes/trapd00r.zsh-theme
Normal file
95
themes/trapd00r.zsh-theme
Normal file
|
@ -0,0 +1,95 @@
|
||||||
|
# Name: trapd00r zsh theme
|
||||||
|
# Author: Magnus Woldrich <m@japh.se>
|
||||||
|
#
|
||||||
|
# This theme needs a terminal supporting 256 colors as well as unicode. It also
|
||||||
|
# needs the script that splits up the current path and makes it fancy as located
|
||||||
|
# here: https://github.com/trapd00r/utils/blob/master/zsh_path
|
||||||
|
#
|
||||||
|
# By default it spans over two lines like so:
|
||||||
|
#
|
||||||
|
# scp1@shiva:pts/9-> /home » scp1 (0)
|
||||||
|
# >
|
||||||
|
#
|
||||||
|
# that's user@host:pts/-> splitted path (return status)
|
||||||
|
#
|
||||||
|
# If the current directory is a git repository, we span 3 lines;
|
||||||
|
#
|
||||||
|
# git❨ master ❩ DIRTY
|
||||||
|
# scp1@shiva:pts/4-> /home » scp1 » dev » utils (0)
|
||||||
|
# >
|
||||||
|
|
||||||
|
autoload -U add-zsh-hook
|
||||||
|
autoload -Uz vcs_info
|
||||||
|
|
||||||
|
local c0=$( printf "\e[m")
|
||||||
|
local c1=$( printf "\e[38;5;245m")
|
||||||
|
local c2=$( printf "\e[38;5;250m")
|
||||||
|
local c3=$( printf "\e[38;5;242m")
|
||||||
|
local c4=$( printf "\e[38;5;197m")
|
||||||
|
local c5=$( printf "\e[38;5;225m")
|
||||||
|
local c6=$( printf "\e[38;5;240m")
|
||||||
|
local c7=$( printf "\e[38;5;242m")
|
||||||
|
local c8=$( printf "\e[38;5;244m")
|
||||||
|
local c9=$( printf "\e[38;5;162m")
|
||||||
|
local c10=$(printf "\e[1m")
|
||||||
|
local c11=$(printf "\e[38;5;208m\e[1m")
|
||||||
|
local c12=$(printf "\e[38;5;142m\e[1m")
|
||||||
|
local c13=$(printf "\e[38;5;196m\e[1m")
|
||||||
|
|
||||||
|
|
||||||
|
# We dont want to use the extended colorset in the TTY / VC.
|
||||||
|
if [ "$TERM" = "linux" ]; then
|
||||||
|
c1=$( printf "\e[34;1m")
|
||||||
|
c2=$( printf "\e[35m")
|
||||||
|
c3=$( printf "\e[31m")
|
||||||
|
c4=$( printf "\e[31;1m")
|
||||||
|
c5=$( printf "\e[32m")
|
||||||
|
c6=$( printf "\e[32;1m")
|
||||||
|
c7=$( printf "\e[33m")
|
||||||
|
c8=$( printf "\e[33;1m")
|
||||||
|
c9=$( printf "\e[34m")
|
||||||
|
|
||||||
|
c11=$(printf "\e[35;1m")
|
||||||
|
c12=$(printf "\e[36m")
|
||||||
|
c13=$(printf "\e[31;1m")
|
||||||
|
fi
|
||||||
|
|
||||||
|
zstyle ':vcs_info:*' actionformats \
|
||||||
|
'%{$c8%}(%f%s)%{$c7%}-%F{5}[%F{2}%b%F{3}|%F{1}%a%F{5}]%f '
|
||||||
|
|
||||||
|
zstyle ':vcs_info:*' formats \
|
||||||
|
"%{$c8%}%s%%{$c7%}❨ %{$c9%}%{$c11%}%b%{$c7%} ❩%{$reset_color%}%f "
|
||||||
|
|
||||||
|
zstyle ':vcs_info:(sv[nk]|bzr):*' branchformat '%b%F{1}:%F{3}%r'
|
||||||
|
zstyle ':vcs_info:*' enable git
|
||||||
|
|
||||||
|
add-zsh-hook precmd prompt_jnrowe_precmd
|
||||||
|
|
||||||
|
prompt_jnrowe_precmd () {
|
||||||
|
vcs_info
|
||||||
|
if [ "${vcs_info_msg_0_}" = "" ]; then
|
||||||
|
dir_status="%{$c1%}%n%{$c4%}@%{$c2%}%m%{$c0%}:%{$c3%}%l%{$c6%}->%{$(zsh_path)%} %{$c0%}(%{$c5%}%?%{$c0%})"
|
||||||
|
PROMPT='%{$fg_bold[green]%}%p%{$reset_color%}${vcs_info_msg_0_}${dir_status} ${ret_status}%{$reset_color%}
|
||||||
|
> '
|
||||||
|
|
||||||
|
# modified, to be commited
|
||||||
|
elif [[ $(git diff --cached --name-status 2>/dev/null ) != "" ]]; then
|
||||||
|
dir_status="%{$c1%}%n%{$c4%}@%{$c2%}%m%{$c0%}:%{$c3%}%l%{$c6%}->%{$(zsh_path)%} %{$c0%}(%{$c5%}%?%{$c0%})"
|
||||||
|
PROMPT='${vcs_info_msg_0_}%{$30%} %{$bg_bold[red]%}%{$fg_bold[cyan]%}C%{$fg_bold[black]%}OMMIT%{$reset_color%}
|
||||||
|
%{$fg_bold[green]%}%p%{$reset_color%}${dir_status}%{$reset_color%}
|
||||||
|
> '
|
||||||
|
|
||||||
|
elif [[ $(git diff --name-status 2>/dev/null ) != "" ]]; then
|
||||||
|
dir_status="%{$c1%}%n%{$c4%}@%{$c2%}%m%{$c0%}:%{$c3%}%l%{$c6%}->%{$(zsh_path)%} %{$c0%}(%{$c5%}%?%{$c0%})"
|
||||||
|
PROMPT='${vcs_info_msg_0_}%{$bg_bold[red]%}%{$fg_bold[blue]%}D%{$fg_bold[black]%}IRTY%{$reset_color%}
|
||||||
|
%{$fg_bold[green]%}%p%{$reset_color%}${dir_status}%{$reset_color%}
|
||||||
|
%{$c13%}>%{$c0%} '
|
||||||
|
else
|
||||||
|
dir_status="%{$c1%}%n%{$c4%}@%{$c2%}%m%{$c0%}:%{$c3%}%l%{$c6%}->%{$(zsh_path)%} %{$c0%}(%{$c5%}%?%{$c0%})"
|
||||||
|
PROMPT='${vcs_info_msg_0_}
|
||||||
|
%{$fg_bold[green]%}%p%{$reset_color%}${dir_status} ${vcs_info_msg_0_}%{$reset_color%}
|
||||||
|
> '
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# vim: set ft=zsh sw=2 et tw=0:
|
Loading…
Reference in a new issue