mirror of
https://github.com/ohmyzsh/ohmyzsh.git
synced 2025-12-26 02:12:33 +01:00
Merge remote branch 'upstream/master'
This commit is contained in:
commit
a55b0025c3
25 changed files with 267 additions and 21 deletions
|
|
@ -1,4 +1,4 @@
|
||||||
## fixme - the load process here seems a bit bizarre
|
# fixme - the load process here seems a bit bizarre
|
||||||
|
|
||||||
unsetopt menu_complete # do not autoselect the first completion entry
|
unsetopt menu_complete # do not autoselect the first completion entry
|
||||||
unsetopt flowcontrol
|
unsetopt flowcontrol
|
||||||
|
|
@ -30,6 +30,11 @@ zstyle ':completion:*:*:*:*:*' menu select
|
||||||
zstyle ':completion:*:*:kill:*:processes' list-colors '=(#b) #([0-9]#) ([0-9a-z-]#)*=01;34=0=01'
|
zstyle ':completion:*:*:kill:*:processes' list-colors '=(#b) #([0-9]#) ([0-9a-z-]#)*=01;34=0=01'
|
||||||
zstyle ':completion:*:*:*:*:processes' command "ps -u `whoami` -o pid,user,comm -w -w"
|
zstyle ':completion:*:*:*:*:processes' command "ps -u `whoami` -o pid,user,comm -w -w"
|
||||||
|
|
||||||
|
# disable named-directories autocompletion
|
||||||
|
zstyle ':completion:*:cd:*' tag-order local-directories directory-stack path-directories
|
||||||
|
cdpath=(.)
|
||||||
|
|
||||||
|
|
||||||
# Load known hosts file for auto-completion with ssh and scp commands
|
# Load known hosts file for auto-completion with ssh and scp commands
|
||||||
if [ -f ~/.ssh/known_hosts ]; then
|
if [ -f ~/.ssh/known_hosts ]; then
|
||||||
zstyle ':completion:*' hosts $( sed 's/[, ].*$//' $HOME/.ssh/known_hosts )
|
zstyle ':completion:*' hosts $( sed 's/[, ].*$//' $HOME/.ssh/known_hosts )
|
||||||
|
|
|
||||||
|
|
@ -5,7 +5,7 @@ function title {
|
||||||
print -nR $'\033k'$1$'\033'\\\
|
print -nR $'\033k'$1$'\033'\\\
|
||||||
|
|
||||||
print -nR $'\033]0;'$2$'\a'
|
print -nR $'\033]0;'$2$'\a'
|
||||||
elif [[ $TERM == "xterm" || $TERM == "rxvt" ]]; then
|
elif [[ $TERM =~ "^xterm" || $TERM == "rxvt" ]]; then
|
||||||
# Use this one instead for XTerms:
|
# Use this one instead for XTerms:
|
||||||
print -nR $'\033]0;'$*$'\a'
|
print -nR $'\033]0;'$*$'\a'
|
||||||
fi
|
fi
|
||||||
|
|
|
||||||
|
|
@ -20,6 +20,7 @@ bindkey "^[[F" end-of-line
|
||||||
bindkey "^[[4~" end-of-line
|
bindkey "^[[4~" end-of-line
|
||||||
bindkey ' ' magic-space # also do history expansion on space
|
bindkey ' ' magic-space # also do history expansion on space
|
||||||
|
|
||||||
|
bindkey '^[[Z' reverse-menu-complete
|
||||||
|
|
||||||
# consider emacs keybindings:
|
# consider emacs keybindings:
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -12,7 +12,7 @@ for config_file ($ZSH/custom/*.zsh) source $config_file
|
||||||
|
|
||||||
# Load all of the plugins that were defined in ~/.zshrc
|
# Load all of the plugins that were defined in ~/.zshrc
|
||||||
plugin=${plugin:=()}
|
plugin=${plugin:=()}
|
||||||
for plugin ($plugins) source $ZSH/plugins/$plugin.plugin.zsh
|
for plugin ($plugins) source $ZSH/plugins/$plugin/$plugin.plugin.zsh
|
||||||
|
|
||||||
# Check for updates on initial load...
|
# Check for updates on initial load...
|
||||||
if [ "$DISABLE_AUTO_UPDATE" = "true" ]
|
if [ "$DISABLE_AUTO_UPDATE" = "true" ]
|
||||||
|
|
@ -21,5 +21,3 @@ then
|
||||||
else
|
else
|
||||||
/usr/bin/env zsh $ZSH/tools/check_for_upgrade.sh
|
/usr/bin/env zsh $ZSH/tools/check_for_upgrade.sh
|
||||||
fi
|
fi
|
||||||
|
|
||||||
unset config_file
|
|
||||||
|
|
@ -1,4 +1,5 @@
|
||||||
#compdef brew
|
#compdef brew
|
||||||
|
#autoload
|
||||||
|
|
||||||
# imported from the latest homebrew contributions
|
# imported from the latest homebrew contributions
|
||||||
|
|
||||||
|
|
@ -65,3 +66,4 @@ case "$words[1]" in
|
||||||
_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
|
||||||
|
|
||||||
4
plugins/brew/brew.plugin.zsh
Normal file
4
plugins/brew/brew.plugin.zsh
Normal file
|
|
@ -0,0 +1,4 @@
|
||||||
|
# add brew completion function to path
|
||||||
|
fpath=($ZSH/plugins/brew $fpath)
|
||||||
|
autoload -U compinit
|
||||||
|
compinit -i
|
||||||
|
|
@ -1,14 +1,3 @@
|
||||||
|
|
||||||
alias ss='thin --stats "/thin/stats" start'
|
|
||||||
alias sg='ruby script/generate'
|
|
||||||
alias sd='ruby script/destroy'
|
|
||||||
alias sp='ruby script/plugin'
|
|
||||||
alias ssp='ruby script/spec'
|
|
||||||
alias rdbm='rake db:migrate'
|
|
||||||
alias sc='ruby script/console'
|
|
||||||
alias sd='ruby script/server --debugger'
|
|
||||||
alias devlog='tail -f log/development.log'
|
|
||||||
|
|
||||||
function _cap_does_task_list_need_generating () {
|
function _cap_does_task_list_need_generating () {
|
||||||
if [ ! -f .cap_tasks~ ]; then return 0;
|
if [ ! -f .cap_tasks~ ]; then return 0;
|
||||||
else
|
else
|
||||||
|
|
@ -30,7 +19,3 @@ function _cap () {
|
||||||
}
|
}
|
||||||
|
|
||||||
compctl -K _cap cap
|
compctl -K _cap cap
|
||||||
|
|
||||||
function remote_console() {
|
|
||||||
/usr/bin/env ssh $1 "( cd $2 && ruby script/console production )"
|
|
||||||
}
|
|
||||||
39
plugins/dirpersist/dirpersist.plugin.zsh
Normal file
39
plugins/dirpersist/dirpersist.plugin.zsh
Normal file
|
|
@ -0,0 +1,39 @@
|
||||||
|
#!/bin/zsh
|
||||||
|
#
|
||||||
|
# Make the dirstack more persistant
|
||||||
|
#
|
||||||
|
# Add dirpersist to $plugins in ~/.zshrc to load
|
||||||
|
#
|
||||||
|
|
||||||
|
# $zdirstore is the file used to persist the stack
|
||||||
|
zdirstore=~/.zdirstore
|
||||||
|
|
||||||
|
dirpersistinstall () {
|
||||||
|
if grep 'dirpersiststore' ~/.zlogout > /dev/null; then
|
||||||
|
else
|
||||||
|
if read -q \?"Would you like to set up your .zlogout file for use with dirspersist? (y/n) "; then
|
||||||
|
echo "# Store dirs stack\n# See ~/.oh-my-zsh/plugins/dirspersist.plugin.zsh\ndirpersiststore" >> ~/.zlogout
|
||||||
|
else
|
||||||
|
echo "If you don't want this message to appear, remove dirspersist from \$plugins"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
dirpersiststore () {
|
||||||
|
dirs -p | perl -e 'foreach (reverse <STDIN>) {chomp;s/([& ])/\\$1/g ;print "if [ -d $_ ]; then pushd -q $_; fi\n"}' > $zdirstore
|
||||||
|
}
|
||||||
|
|
||||||
|
dirpersistrestore () {
|
||||||
|
if [ -f $zdirstore ]; then
|
||||||
|
source $zdirstore
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
DIRSTACKSIZE=10
|
||||||
|
setopt autopushd pushdminus pushdsilent pushdtohome pushdignoredups
|
||||||
|
|
||||||
|
dirpersistinstall
|
||||||
|
dirpersistrestore
|
||||||
|
|
||||||
|
# Make popd changes permanent without having to wait for logout
|
||||||
|
alias popd="popd;dirpersiststore"
|
||||||
64
plugins/gem/_gem
Normal file
64
plugins/gem/_gem
Normal file
|
|
@ -0,0 +1,64 @@
|
||||||
|
#compdef gem
|
||||||
|
#autoload
|
||||||
|
|
||||||
|
# gem zsh completion, based on homebrew completion
|
||||||
|
|
||||||
|
_gem_installed() {
|
||||||
|
installed_gems=(`gem list --local --no-versions`)
|
||||||
|
}
|
||||||
|
|
||||||
|
local -a _1st_arguments
|
||||||
|
_1st_arguments=(
|
||||||
|
'cert:Manage RubyGems certificates and signing settings'
|
||||||
|
'check:Check installed gems'
|
||||||
|
'cleanup:Clean up old versions of installed gems in the local repository'
|
||||||
|
'contents:Display the contents of the installed gems'
|
||||||
|
'dependency:Show the dependencies of an installed gem'
|
||||||
|
'environment:Display information about the RubyGems environment'
|
||||||
|
'fetch:Download a gem and place it in the current directory'
|
||||||
|
'generate_index:Generates the index files for a gem server directory'
|
||||||
|
'help:Provide help on the `gem` command'
|
||||||
|
'install:Install a gem into the local repository'
|
||||||
|
'list:Display gems whose name starts with STRING'
|
||||||
|
'lock:Generate a lockdown list of gems'
|
||||||
|
'mirror:Mirror a gem repository'
|
||||||
|
'outdated:Display all gems that need updates'
|
||||||
|
'owner:Manage gem owners on RubyGems.org.'
|
||||||
|
'pristine:Restores installed gems to pristine condition from files located in the gem cache'
|
||||||
|
'push:Push a gem up to RubyGems.org'
|
||||||
|
'query:Query gem information in local or remote repositories'
|
||||||
|
'rdoc:Generates RDoc for pre-installed gems'
|
||||||
|
'search:Display all gems whose name contains STRING'
|
||||||
|
'server:Documentation and gem repository HTTP server'
|
||||||
|
'sources:Manage the sources and cache file RubyGems uses to search for gems'
|
||||||
|
'specification:Display gem specification (in yaml)'
|
||||||
|
'stale:List gems along with access times'
|
||||||
|
'uninstall:Uninstall gems from the local repository'
|
||||||
|
'unpack:Unpack an installed gem to the current directory'
|
||||||
|
'update:Update the named gems (or all installed gems) in the local repository'
|
||||||
|
'which:Find the location of a library file you can require'
|
||||||
|
)
|
||||||
|
|
||||||
|
local expl
|
||||||
|
local -a gems installed_gems
|
||||||
|
|
||||||
|
_arguments \
|
||||||
|
'(-v --version)'{-v,--version}'[show version]' \
|
||||||
|
'(-h --help)'{-h,--help}'[show help]' \
|
||||||
|
'*:: :->subcmds' && return 0
|
||||||
|
|
||||||
|
if (( CURRENT == 1 )); then
|
||||||
|
_describe -t commands "gem subcommand" _1st_arguments
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
case "$words[1]" in
|
||||||
|
list)
|
||||||
|
if [[ "$state" == forms ]]; then
|
||||||
|
_gem_installed
|
||||||
|
_requested installed_gems expl 'installed gems' compadd -a installed_gems
|
||||||
|
fi ;;
|
||||||
|
uninstall|update)
|
||||||
|
_gem_installed
|
||||||
|
_wanted installed_gems expl 'installed gems' compadd -a installed_gems ;;
|
||||||
|
esac
|
||||||
4
plugins/gem/gem.plugin.zsh
Normal file
4
plugins/gem/gem.plugin.zsh
Normal file
|
|
@ -0,0 +1,4 @@
|
||||||
|
# add brew completion function to path
|
||||||
|
fpath=($ZSH/plugins/gem $fpath)
|
||||||
|
autoload -U compinit
|
||||||
|
compinit -i
|
||||||
7
plugins/macports/macports.plugin.zsh
Normal file
7
plugins/macports/macports.plugin.zsh
Normal file
|
|
@ -0,0 +1,7 @@
|
||||||
|
#Aliases
|
||||||
|
alias pc="sudo port clean --all installed"
|
||||||
|
alias pi="sudo port install $1"
|
||||||
|
alias psu="sudo port selfupdate"
|
||||||
|
alias puni="sudo port uninstall inactive"
|
||||||
|
alias puo="sudo port upgrade outdated"
|
||||||
|
alias pup="psu && puo"
|
||||||
46
plugins/pip/_pip
Normal file
46
plugins/pip/_pip
Normal file
|
|
@ -0,0 +1,46 @@
|
||||||
|
#compdef pip
|
||||||
|
#autoload
|
||||||
|
|
||||||
|
# pip zsh completion, based on homebrew completion
|
||||||
|
|
||||||
|
_pip_installed() {
|
||||||
|
installed_pkgs=(`pip freeze`)
|
||||||
|
}
|
||||||
|
|
||||||
|
local -a _1st_arguments
|
||||||
|
_1st_arguments=(
|
||||||
|
'bundle:Create pybundles (archives containing multiple packages)'
|
||||||
|
'freeze:Output all currently installed packages (exact versions) to stdout'
|
||||||
|
'help:Show available commands'
|
||||||
|
'install:Install packages'
|
||||||
|
'search:Search PyPI'
|
||||||
|
'uninstall:Uninstall packages'
|
||||||
|
'unzip:Unzip individual packages'
|
||||||
|
'zip:Zip individual packages'
|
||||||
|
)
|
||||||
|
|
||||||
|
local expl
|
||||||
|
local -a pkgs installed_pkgs
|
||||||
|
|
||||||
|
_arguments \
|
||||||
|
'(--version)--version[Show version number of program and exit]' \
|
||||||
|
'(-v --verbose)'{-v,--verbose}'[Give more output]' \
|
||||||
|
'(-q --quiet)'{-q,--quiet}'[Give less output]' \
|
||||||
|
'(-h --help)'{-h,--help}'[Show help]' \
|
||||||
|
'*:: :->subcmds' && return 0
|
||||||
|
|
||||||
|
if (( CURRENT == 1 )); then
|
||||||
|
_describe -t commands "pip subcommand" _1st_arguments
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
case "$words[1]" in
|
||||||
|
list)
|
||||||
|
if [[ "$state" == forms ]]; then
|
||||||
|
_pip_installed
|
||||||
|
_requested installed_pkgs expl 'installed packages' compadd -a installed_pkgs
|
||||||
|
fi ;;
|
||||||
|
uninstall)
|
||||||
|
_pip_installed
|
||||||
|
_wanted installed_pkgs expl 'installed packages' compadd -a installed_pkgs ;;
|
||||||
|
esac
|
||||||
4
plugins/pip/pip.plugin.zsh
Normal file
4
plugins/pip/pip.plugin.zsh
Normal file
|
|
@ -0,0 +1,4 @@
|
||||||
|
# add brew completion function to path
|
||||||
|
fpath=($ZSH/plugins/pip $fpath)
|
||||||
|
autoload -U compinit
|
||||||
|
compinit -i
|
||||||
13
plugins/rails/rails.plugin.zsh
Normal file
13
plugins/rails/rails.plugin.zsh
Normal file
|
|
@ -0,0 +1,13 @@
|
||||||
|
alias ss='thin --stats "/thin/stats" start'
|
||||||
|
alias sg='ruby script/generate'
|
||||||
|
alias sd='ruby script/destroy'
|
||||||
|
alias sp='ruby script/plugin'
|
||||||
|
alias ssp='ruby script/spec'
|
||||||
|
alias rdbm='rake db:migrate'
|
||||||
|
alias sc='ruby script/console'
|
||||||
|
alias sd='ruby script/server --debugger'
|
||||||
|
alias devlog='tail -f log/development.log'
|
||||||
|
|
||||||
|
function remote_console() {
|
||||||
|
/usr/bin/env ssh $1 "( cd $2 && ruby script/console production )"
|
||||||
|
}
|
||||||
23
plugins/ssh-agent/ssh-agent.plugin.zsh
Normal file
23
plugins/ssh-agent/ssh-agent.plugin.zsh
Normal file
|
|
@ -0,0 +1,23 @@
|
||||||
|
# Based on code from Joseph M. Reagle
|
||||||
|
# http://www.cygwin.com/ml/cygwin/2001-06/msg00537.html
|
||||||
|
|
||||||
|
local SSH_ENV=$HOME/.ssh/environment
|
||||||
|
|
||||||
|
function start_agent {
|
||||||
|
/usr/bin/env ssh-agent | sed 's/^echo/#echo/' > ${SSH_ENV}
|
||||||
|
chmod 600 ${SSH_ENV}
|
||||||
|
. ${SSH_ENV} > /dev/null
|
||||||
|
/usr/bin/ssh-add;
|
||||||
|
}
|
||||||
|
|
||||||
|
# Source SSH settings, if applicable
|
||||||
|
|
||||||
|
if [ -f "${SSH_ENV}" ]; then
|
||||||
|
. ${SSH_ENV} > /dev/null
|
||||||
|
ps -ef | grep ${SSH_AGENT_PID} | grep ssh-agent$ > /dev/null || {
|
||||||
|
start_agent;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
start_agent;
|
||||||
|
fi
|
||||||
|
|
||||||
22
plugins/vi-mode/vi-mode.plugin.zsh
Normal file
22
plugins/vi-mode/vi-mode.plugin.zsh
Normal file
|
|
@ -0,0 +1,22 @@
|
||||||
|
function zle-line-init zle-keymap-select {
|
||||||
|
zle reset-prompt
|
||||||
|
}
|
||||||
|
|
||||||
|
zle -N zle-line-init
|
||||||
|
zle -N zle-keymap-select
|
||||||
|
|
||||||
|
bindkey -v
|
||||||
|
|
||||||
|
# if mode indicator wasn't setup by theme, define default
|
||||||
|
if [[ "$MODE_INDICATOR" == "" ]]; then
|
||||||
|
MODE_INDICATOR="%{$fg_bold[red]%}<%{$fg[red]%}<<%{$reset_color%}"
|
||||||
|
fi
|
||||||
|
|
||||||
|
function vi_mode_prompt_info() {
|
||||||
|
echo "${${KEYMAP/vicmd/$MODE_INDICATOR}/(main|viins)/}"
|
||||||
|
}
|
||||||
|
|
||||||
|
# define right prompt, if it wasn't defined by a theme
|
||||||
|
if [[ "$RPS1" == "" && "$RPROMPT" == "" ]]; then
|
||||||
|
RPS1='$(vi_mode_prompt_info)'
|
||||||
|
fi
|
||||||
13
themes/kennethreitz.zsh-theme
Normal file
13
themes/kennethreitz.zsh-theme
Normal file
|
|
@ -0,0 +1,13 @@
|
||||||
|
local return_code="%(?..%{$fg[red]%}%? ↵%{$reset_color%})"
|
||||||
|
|
||||||
|
PROMPT='%{$fg[green]%}%c \
|
||||||
|
$(git_prompt_info)\
|
||||||
|
%{$fg[red]%}%(!.#.»)%{$reset_color%} '
|
||||||
|
PROMPT2='%{$fg[red]%}\ %{$reset_color%}'
|
||||||
|
RPS1='%{$fg[blue]%}%~%{$reset_color%} ${return_code} '
|
||||||
|
|
||||||
|
ZSH_THEME_GIT_PROMPT_PREFIX="%{$reset_color%}:: %{$fg[yellow]%}("
|
||||||
|
ZSH_THEME_GIT_PROMPT_SUFFIX=")%{$reset_color%} "
|
||||||
|
ZSH_THEME_GIT_PROMPT_CLEAN=""
|
||||||
|
ZSH_THEME_GIT_PROMPT_DIRTY="%{$fg[red]%}*%{$fg[yellow]%}"
|
||||||
|
|
||||||
10
themes/lukerandall.zsh-theme
Normal file
10
themes/lukerandall.zsh-theme
Normal file
|
|
@ -0,0 +1,10 @@
|
||||||
|
# ZSH Theme - Preview: http://cl.ly/f701d00760f8059e06dc
|
||||||
|
# Thanks to gallifrey, upon whose theme this is based
|
||||||
|
|
||||||
|
local return_code="%(?..%{$fg_bold[red]%}%? ↵%{$reset_color%})"
|
||||||
|
|
||||||
|
PROMPT='%{$fg_bold[green]%}%n@%m%{$reset_color%} %{$fg_bold[blue]%}%2~%{$reset_color%} $(git_prompt_info)%{$reset_color%}%B»%b '
|
||||||
|
RPS1="${return_code}"
|
||||||
|
|
||||||
|
ZSH_THEME_GIT_PROMPT_PREFIX="%{$fg[yellow]%}("
|
||||||
|
ZSH_THEME_GIT_PROMPT_SUFFIX=") %{$reset_color%}"
|
||||||
6
themes/theunraveler.zsh-theme
Normal file
6
themes/theunraveler.zsh-theme
Normal file
|
|
@ -0,0 +1,6 @@
|
||||||
|
# Comment
|
||||||
|
|
||||||
|
ZSH_THEME_GIT_PROMPT_PREFIX=' (git:'
|
||||||
|
ZSH_THEME_GIT_PROMPT_SUFFIX=')'
|
||||||
|
|
||||||
|
PROMPT='%{$fg[magenta]%}[%c]$(git_prompt_info) $ %{$reset_color%}'
|
||||||
Loading…
Add table
Add a link
Reference in a new issue