Merge branch 'master' of http://github.com/robbyrussell/oh-my-zsh
This commit is contained in:
commit
2b55ee0753
2
.gitignore
vendored
2
.gitignore
vendored
|
@ -2,5 +2,7 @@ locals.zsh
|
||||||
log/.zsh_history
|
log/.zsh_history
|
||||||
projects.zsh
|
projects.zsh
|
||||||
custom/*
|
custom/*
|
||||||
|
!custom/example
|
||||||
!custom/example.zsh
|
!custom/example.zsh
|
||||||
cache
|
cache
|
||||||
|
*.swp
|
||||||
|
|
|
@ -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.
|
|
@ -22,4 +22,3 @@ alias sl=ls # often screw this up
|
||||||
|
|
||||||
alias afind='ack-grep -il'
|
alias afind='ack-grep -il'
|
||||||
|
|
||||||
alias x=extract
|
|
||||||
|
|
|
@ -59,3 +59,12 @@ zstyle ':completion:*:*:*:users' ignored-patterns \
|
||||||
# ... unless we really want to.
|
# ... unless we really want to.
|
||||||
zstyle '*' single-ignored show
|
zstyle '*' single-ignored show
|
||||||
|
|
||||||
|
if [ "x$COMPLETION_WAITING_DOTS" = "xtrue" ]; then
|
||||||
|
expand-or-complete-with-dots() {
|
||||||
|
echo -n "\e[31m......\e[0m"
|
||||||
|
zle expand-or-complete
|
||||||
|
zle redisplay
|
||||||
|
}
|
||||||
|
zle -N expand-or-complete-with-dots
|
||||||
|
bindkey "^I" expand-or-complete-with-dots
|
||||||
|
fi
|
||||||
|
|
3
lib/edit-command-line.zsh
Normal file
3
lib/edit-command-line.zsh
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
autoload -U edit-command-line
|
||||||
|
zle -N edit-command-line
|
||||||
|
bindkey '\C-x\C-e' edit-command-line
|
|
@ -15,38 +15,3 @@ function take() {
|
||||||
cd $1
|
cd $1
|
||||||
}
|
}
|
||||||
|
|
||||||
function extract() {
|
|
||||||
unset REMOVE_ARCHIVE
|
|
||||||
|
|
||||||
if test "$1" = "-r"; then
|
|
||||||
REMOVE=1
|
|
||||||
shift
|
|
||||||
fi
|
|
||||||
if [[ -f $1 ]]; then
|
|
||||||
case $1 in
|
|
||||||
*.tar.bz2) tar xvjf $1;;
|
|
||||||
*.tar.gz) tar xvzf $1;;
|
|
||||||
*.tar.xz) tar xvJf $1;;
|
|
||||||
*.tar.lzma) tar --lzma -xvf $1;;
|
|
||||||
*.bz2) bunzip $1;;
|
|
||||||
*.rar) unrar $1;;
|
|
||||||
*.gz) gunzip $1;;
|
|
||||||
*.tar) tar xvf $1;;
|
|
||||||
*.tbz2) tar xvjf $1;;
|
|
||||||
*.tgz) tar xvzf $1;;
|
|
||||||
*.zip) unzip $1;;
|
|
||||||
*.Z) uncompress $1;;
|
|
||||||
*.7z) 7z x $1;;
|
|
||||||
*) echo "'$1' cannot be extracted via >extract<";;
|
|
||||||
esac
|
|
||||||
|
|
||||||
if [[ $REMOVE_ARCHIVE -eq 1 ]]; then
|
|
||||||
echo removing "$1";
|
|
||||||
/bin/rm "$1";
|
|
||||||
fi
|
|
||||||
|
|
||||||
else
|
|
||||||
echo "'$1' is not a valid file"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
|
@ -15,7 +15,7 @@ parse_git_dirty() {
|
||||||
|
|
||||||
# Checks if there are commits ahead from remote
|
# Checks if there are commits ahead from remote
|
||||||
function git_prompt_ahead() {
|
function git_prompt_ahead() {
|
||||||
if $(echo "$(git log origin/master..HEAD 2> /dev/null)" | grep '^commit' &> /dev/null); then
|
if $(echo "$(git log origin/$(current_branch)..HEAD 2> /dev/null)" | grep '^commit' &> /dev/null); then
|
||||||
echo "$ZSH_THEME_GIT_PROMPT_AHEAD"
|
echo "$ZSH_THEME_GIT_PROMPT_AHEAD"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
@ -54,6 +54,8 @@ git_prompt_status() {
|
||||||
fi
|
fi
|
||||||
if $(echo "$INDEX" | grep '^ D ' &> /dev/null); then
|
if $(echo "$INDEX" | grep '^ D ' &> /dev/null); then
|
||||||
STATUS="$ZSH_THEME_GIT_PROMPT_DELETED$STATUS"
|
STATUS="$ZSH_THEME_GIT_PROMPT_DELETED$STATUS"
|
||||||
|
elif $(echo "$INDEX" | grep '^AD ' &> /dev/null); then
|
||||||
|
STATUS="$ZSH_THEME_GIT_PROMPT_DELETED$STATUS"
|
||||||
fi
|
fi
|
||||||
if $(echo "$INDEX" | grep '^UU ' &> /dev/null); then
|
if $(echo "$INDEX" | grep '^UU ' &> /dev/null); then
|
||||||
STATUS="$ZSH_THEME_GIT_PROMPT_UNMERGED$STATUS"
|
STATUS="$ZSH_THEME_GIT_PROMPT_UNMERGED$STATUS"
|
||||||
|
|
|
@ -14,12 +14,23 @@ bindkey '^[[B' down-line-or-search
|
||||||
|
|
||||||
bindkey "^[[H" beginning-of-line
|
bindkey "^[[H" beginning-of-line
|
||||||
bindkey "^[[1~" beginning-of-line
|
bindkey "^[[1~" beginning-of-line
|
||||||
|
bindkey "^[OH" beginning-of-line
|
||||||
bindkey "^[[F" end-of-line
|
bindkey "^[[F" end-of-line
|
||||||
bindkey "^[[4~" end-of-line
|
bindkey "^[[4~" end-of-line
|
||||||
|
bindkey "^[OF" end-of-line
|
||||||
bindkey ' ' magic-space # also do history expansion on space
|
bindkey ' ' magic-space # also do history expansion on space
|
||||||
|
|
||||||
|
bindkey "^[[1;5C" forward-word
|
||||||
|
bindkey "^[[1;5D" backward-word
|
||||||
|
|
||||||
bindkey '^[[Z' reverse-menu-complete
|
bindkey '^[[Z' reverse-menu-complete
|
||||||
|
|
||||||
|
# Make the delete key (or Fn + Delete on the Mac) work instead of outputting a ~
|
||||||
|
bindkey '^?' backward-delete-char
|
||||||
|
bindkey "^[[3~" delete-char
|
||||||
|
bindkey "^[3;5~" delete-char
|
||||||
|
bindkey "\e[3~" delete-char
|
||||||
|
|
||||||
# consider emacs keybindings:
|
# consider emacs keybindings:
|
||||||
|
|
||||||
#bindkey -e ## emacs key bindings
|
#bindkey -e ## emacs key bindings
|
||||||
|
|
|
@ -10,4 +10,4 @@ setopt long_list_jobs
|
||||||
|
|
||||||
## pager
|
## pager
|
||||||
export PAGER=less
|
export PAGER=less
|
||||||
export LC_CTYPE=en_US.UTF-8
|
export LC_CTYPE=$LANG
|
||||||
|
|
|
@ -18,3 +18,11 @@ for color in {000..255}; do
|
||||||
FG[$color]="%{[38;5;${color}m%}"
|
FG[$color]="%{[38;5;${color}m%}"
|
||||||
BG[$color]="%{[48;5;${color}m%}"
|
BG[$color]="%{[48;5;${color}m%}"
|
||||||
done
|
done
|
||||||
|
|
||||||
|
# Show all 256 colors with color number
|
||||||
|
function spectrum_ls() {
|
||||||
|
for code in {000..255}; do
|
||||||
|
print -P -- "$code: %F{$code}Test%f"
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
|
26
oh-my-zsh.sh
26
oh-my-zsh.sh
|
@ -1,7 +1,13 @@
|
||||||
|
# Check for updates on initial load...
|
||||||
|
if [ "$DISABLE_AUTO_UPDATE" != "true" ]
|
||||||
|
then
|
||||||
|
/usr/bin/env zsh $ZSH/tools/check_for_upgrade.sh
|
||||||
|
fi
|
||||||
|
|
||||||
# Initializes Oh My Zsh
|
# Initializes Oh My Zsh
|
||||||
|
|
||||||
# add a function path
|
# add a function path
|
||||||
fpath=($ZSH/functions $fpath)
|
fpath=($ZSH/functions $ZSH/completions $fpath)
|
||||||
|
|
||||||
# Load all of the config files in ~/oh-my-zsh that end in .zsh
|
# Load all of the config files in ~/oh-my-zsh that end in .zsh
|
||||||
# TIP: Add files you don't want in git to .gitignore
|
# TIP: Add files you don't want in git to .gitignore
|
||||||
|
@ -17,7 +23,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
|
||||||
|
@ -26,24 +34,18 @@ done
|
||||||
for config_file ($ZSH/custom/*.zsh) source $config_file
|
for config_file ($ZSH/custom/*.zsh) source $config_file
|
||||||
|
|
||||||
# Load the theme
|
# Load the theme
|
||||||
# Check for updates on initial load...
|
|
||||||
if [ "$ZSH_THEME" = "random" ]
|
if [ "$ZSH_THEME" = "random" ]
|
||||||
then
|
then
|
||||||
themes=($ZSH/themes/*zsh-theme)
|
themes=($ZSH/themes/*zsh-theme)
|
||||||
N=${#themes[@]}
|
N=${#themes[@]}
|
||||||
((N=RANDOM%N))
|
((N=(RANDOM%N)+1))
|
||||||
RANDOM_THEME=${themes[$N]}
|
RANDOM_THEME=${themes[$N]}
|
||||||
source "$RANDOM_THEME"
|
source "$RANDOM_THEME"
|
||||||
echo "[oh-my-zsh] Random theme '$RANDOM_THEME' loaded..."
|
echo "[oh-my-zsh] Random theme '$RANDOM_THEME' loaded..."
|
||||||
else
|
else
|
||||||
|
if [ ! "$ZSH_THEME" = "" ]
|
||||||
|
then
|
||||||
source "$ZSH/themes/$ZSH_THEME.zsh-theme"
|
source "$ZSH/themes/$ZSH_THEME.zsh-theme"
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
# Check for updates on initial load...
|
|
||||||
if [ "$DISABLE_AUTO_UPDATE" = "true" ]
|
|
||||||
then
|
|
||||||
return
|
|
||||||
else
|
|
||||||
/usr/bin/env zsh $ZSH/tools/check_for_upgrade.sh
|
|
||||||
fi
|
|
||||||
|
|
26
plugins/ant/ant.plugin.zsh
Normal file
26
plugins/ant/ant.plugin.zsh
Normal file
|
@ -0,0 +1,26 @@
|
||||||
|
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 () {
|
||||||
|
if [ ! -f .ant_targets ]; then return 0;
|
||||||
|
else
|
||||||
|
accurate=$($stat_cmd .ant_targets)
|
||||||
|
changed=$($stat_cmd build.xml)
|
||||||
|
return $(expr $accurate '>=' $changed)
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
_ant () {
|
||||||
|
if [ -f build.xml ]; then
|
||||||
|
if _ant_does_target_list_need_generating; then
|
||||||
|
sed -n '/<target/s/<target.*name="\([^"]*\).*$/\1/p' build.xml > .ant_targets
|
||||||
|
fi
|
||||||
|
compadd `cat .ant_targets`
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
compdef _ant ant
|
6
plugins/apache2-macports/apache2-macports.plugin.zsh
Normal file
6
plugins/apache2-macports/apache2-macports.plugin.zsh
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
# commands to control local apache2 server installation
|
||||||
|
# paths are for osx installation via macports
|
||||||
|
|
||||||
|
alias apache2start='sudo /opt/local/etc/LaunchDaemons/org.macports.apache2/apache2.wrapper start'
|
||||||
|
alias apache2stop='sudo /opt/local/etc/LaunchDaemons/org.macports.apache2/apache2.wrapper stop'
|
||||||
|
alias apache2restart='sudo /opt/local/etc/LaunchDaemons/org.macports.apache2/apache2.wrapper restart'
|
76
plugins/archlinux/archlinux.plugin.zsh
Normal file
76
plugins/archlinux/archlinux.plugin.zsh
Normal file
|
@ -0,0 +1,76 @@
|
||||||
|
# Archlinux zsh aliases and functions
|
||||||
|
# Usage is also described at https://github.com/robbyrussell/oh-my-zsh/wiki/Plugins
|
||||||
|
|
||||||
|
# Look for yaourt, and add some useful functions if we have it.
|
||||||
|
if [[ -x `which yaourt` ]]; then
|
||||||
|
upgrade () {
|
||||||
|
yaourt -Syu
|
||||||
|
}
|
||||||
|
alias yaconf='yaourt -C' # Fix all configuration files with vimdiff
|
||||||
|
# Pacman - https://wiki.archlinux.org/index.php/Pacman_Tips
|
||||||
|
alias yaupg='yaourt -Syu' # Synchronize with repositories before upgrading packages that are out of date on the local system.
|
||||||
|
alias yain='yaourt -S' # Install specific package(s) from the repositories
|
||||||
|
alias yains='yaourt -U' # Install specific package not from the repositories but from a file
|
||||||
|
alias yare='yaourt -R' # Remove the specified package(s), retaining its configuration(s) and required dependencies
|
||||||
|
alias yarem='yaourt -Rns' # Remove the specified package(s), its configuration(s) and unneeded dependencies
|
||||||
|
alias yarep='yaourt -Si' # Display information about a given package in the repositories
|
||||||
|
alias yareps='yaourt -Ss' # Search for package(s) in the repositories
|
||||||
|
alias yaloc='yaourt -Qi' # Display information about a given package in the local database
|
||||||
|
alias yalocs='yaourt -Qs' # Search for package(s) in the local database
|
||||||
|
# Additional yaourt alias examples
|
||||||
|
if [[ -x `which abs` ]]; then
|
||||||
|
alias yaupd='yaourt -Sy && sudo abs' # Update and refresh the local package and ABS databases against repositories
|
||||||
|
else
|
||||||
|
alias yaupd='yaourt -Sy' # Update and refresh the local package and ABS databases against repositories
|
||||||
|
fi
|
||||||
|
alias yainsd='yaourt -S --asdeps' # Install given package(s) as dependencies of another package
|
||||||
|
alias yamir='yaourt -Syy' # Force refresh of all package lists after updating /etc/pacman.d/mirrorlist
|
||||||
|
else
|
||||||
|
upgrade() {
|
||||||
|
sudo pacman -Syu
|
||||||
|
}
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Pacman - https://wiki.archlinux.org/index.php/Pacman_Tips
|
||||||
|
alias pacupg='sudo pacman -Syu' # Synchronize with repositories before upgrading packages that are out of date on the local system.
|
||||||
|
alias pacin='sudo pacman -S' # Install specific package(s) from the repositories
|
||||||
|
alias pacins='sudo pacman -U' # Install specific package not from the repositories but from a file
|
||||||
|
alias pacre='sudo pacman -R' # Remove the specified package(s), retaining its configuration(s) and required dependencies
|
||||||
|
alias pacrem='sudo pacman -Rns' # Remove the specified package(s), its configuration(s) and unneeded dependencies
|
||||||
|
alias pacrep='pacman -Si' # Display information about a given package in the repositories
|
||||||
|
alias pacreps='pacman -Ss' # Search for package(s) in the repositories
|
||||||
|
alias pacloc='pacman -Qi' # Display information about a given package in the local database
|
||||||
|
alias paclocs='pacman -Qs' # Search for package(s) in the local database
|
||||||
|
# Additional pacman alias examples
|
||||||
|
if [[ -x `which abs` ]]; then
|
||||||
|
alias pacupd='sudo pacman -Sy && sudo abs' # Update and refresh the local package and ABS databases against repositories
|
||||||
|
else
|
||||||
|
alias pacupd='sudo pacman -Sy' # Update and refresh the local package and ABS databases against repositories
|
||||||
|
fi
|
||||||
|
alias pacinsd='sudo pacman -S --asdeps' # Install given package(s) as dependencies of another package
|
||||||
|
alias pacmir='sudo pacman -Syy' # Force refresh of all package lists after updating /etc/pacman.d/mirrorlist
|
||||||
|
|
||||||
|
# https://bbs.archlinux.org/viewtopic.php?id=93683
|
||||||
|
paclist() {
|
||||||
|
sudo pacman -Qei $(pacman -Qu|cut -d" " -f 1)|awk ' BEGIN {FS=":"}/^Name/{printf("\033[1;36m%s\033[1;37m", $2)}/^Description/{print $2}'
|
||||||
|
}
|
||||||
|
|
||||||
|
alias paclsorphans='sudo pacman -Qdt'
|
||||||
|
alias pacrmorphans='sudo pacman -Rs $(pacman -Qtdq)'
|
||||||
|
|
||||||
|
pacdisowned() {
|
||||||
|
tmp=${TMPDIR-/tmp}/pacman-disowned-$UID-$$
|
||||||
|
db=$tmp/db
|
||||||
|
fs=$tmp/fs
|
||||||
|
|
||||||
|
mkdir "$tmp"
|
||||||
|
trap 'rm -rf "$tmp"' EXIT
|
||||||
|
|
||||||
|
pacman -Qlq | sort -u > "$db"
|
||||||
|
|
||||||
|
find /bin /etc /lib /sbin /usr \
|
||||||
|
! -name lost+found \
|
||||||
|
\( -type d -printf '%p/\n' -o -print \) | sort > "$fs"
|
||||||
|
|
||||||
|
comm -23 "$fs" "$db"
|
||||||
|
}
|
3
plugins/autojump/autojump.plugin.zsh
Normal file
3
plugins/autojump/autojump.plugin.zsh
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
if [ -f `brew --prefix`/etc/autojump ]; then
|
||||||
|
. `brew --prefix`/etc/autojump
|
||||||
|
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'
|
|
@ -1,3 +1,37 @@
|
||||||
alias be="bundle exec"
|
alias be="bundle exec"
|
||||||
alias bi="bundle install"
|
alias bi="bundle install"
|
||||||
|
alias bl="bundle list"
|
||||||
alias bu="bundle update"
|
alias bu="bundle update"
|
||||||
|
alias bp="bundle package"
|
||||||
|
|
||||||
|
# The following is based on https://github.com/gma/bundler-exec
|
||||||
|
|
||||||
|
bundled_commands=(cap capify cucumber guard heroku rackup rails rake rspec ruby shotgun spec spork thin unicorn unicorn_rails)
|
||||||
|
|
||||||
|
## Functions
|
||||||
|
|
||||||
|
_bundler-installed() {
|
||||||
|
which bundle > /dev/null 2>&1
|
||||||
|
}
|
||||||
|
|
||||||
|
_within-bundled-project() {
|
||||||
|
local check_dir=$PWD
|
||||||
|
while [ "$(dirname $check_dir)" != "/" ]; do
|
||||||
|
[ -f "$check_dir/Gemfile" ] && return
|
||||||
|
check_dir="$(dirname $check_dir)"
|
||||||
|
done
|
||||||
|
false
|
||||||
|
}
|
||||||
|
|
||||||
|
_run-with-bundler() {
|
||||||
|
if _bundler-installed && _within-bundled-project; then
|
||||||
|
bundle exec $@
|
||||||
|
else
|
||||||
|
$@
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
## Main program
|
||||||
|
for cmd in $bundled_commands; do
|
||||||
|
alias $cmd="_run-with-bundler $cmd"
|
||||||
|
done
|
||||||
|
|
32
plugins/cake/cake.plugin.zsh
Normal file
32
plugins/cake/cake.plugin.zsh
Normal file
|
@ -0,0 +1,32 @@
|
||||||
|
# Set this to 1 if you want to cache the tasks
|
||||||
|
cache_task_list=1
|
||||||
|
|
||||||
|
# Cache filename
|
||||||
|
cache_file='.cake_task_cache'
|
||||||
|
|
||||||
|
_cake_does_target_list_need_generating () {
|
||||||
|
|
||||||
|
if [ $cache_task_list -eq 0 ]; then
|
||||||
|
return 1;
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ ! -f $cache_file ]; then return 0;
|
||||||
|
else
|
||||||
|
accurate=$(stat -f%m $cache_file)
|
||||||
|
changed=$(stat -f%m Cakefile)
|
||||||
|
return $(expr $accurate '>=' $changed)
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
_cake () {
|
||||||
|
if [ -f Cakefile ]; then
|
||||||
|
if _cake_does_target_list_need_generating; then
|
||||||
|
cake | sed -e "s/cake \([^ ]*\) .*/\1/" | grep -v '^$' > $cache_file
|
||||||
|
compadd `cat $cache_file`
|
||||||
|
else
|
||||||
|
compadd `cake | sed -e "s/cake \([^ ]*\) .*/\1/" | grep -v '^$'`
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
compdef _cake cake
|
2
plugins/cloudapp/cloudapp.plugin.zsh
Normal file
2
plugins/cloudapp/cloudapp.plugin.zsh
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
#!/bin/zsh
|
||||||
|
alias cloudapp=$ZSH/plugins/cloudapp/cloudapp.rb
|
60
plugins/cloudapp/cloudapp.rb
Executable file
60
plugins/cloudapp/cloudapp.rb
Executable file
|
@ -0,0 +1,60 @@
|
||||||
|
#!/usr/bin/env ruby
|
||||||
|
#
|
||||||
|
# cloudapp
|
||||||
|
# Zach Holman / @holman
|
||||||
|
#
|
||||||
|
# Uploads a file from the command line to CloudApp, drops it into your
|
||||||
|
# clipboard (on a Mac, at least).
|
||||||
|
#
|
||||||
|
# Example:
|
||||||
|
#
|
||||||
|
# cloudapp drunk-blake.png
|
||||||
|
#
|
||||||
|
# This requires Aaron Russell's cloudapp_api gem:
|
||||||
|
#
|
||||||
|
# gem install cloudapp_api
|
||||||
|
#
|
||||||
|
# Requires you set your CloudApp credentials in ~/.cloudapp as a simple file of:
|
||||||
|
#
|
||||||
|
# email
|
||||||
|
# password
|
||||||
|
|
||||||
|
require 'rubygems'
|
||||||
|
begin
|
||||||
|
require 'cloudapp_api'
|
||||||
|
rescue LoadError
|
||||||
|
puts "You need to install cloudapp_api: gem install cloudapp_api"
|
||||||
|
exit!(1)
|
||||||
|
end
|
||||||
|
|
||||||
|
config_file = "#{ENV['HOME']}/.cloudapp"
|
||||||
|
unless File.exist?(config_file)
|
||||||
|
puts "You need to type your email and password (one per line) into "+
|
||||||
|
"`~/.cloudapp`"
|
||||||
|
exit!(1)
|
||||||
|
end
|
||||||
|
|
||||||
|
email,password = File.read(config_file).split("\n")
|
||||||
|
|
||||||
|
class HTTParty::Response
|
||||||
|
# Apparently HTTPOK.ok? IS NOT OKAY WTFFFFFFFFFFUUUUUUUUUUUUUU
|
||||||
|
# LETS MONKEY PATCH IT I FEEL OKAY ABOUT IT
|
||||||
|
def ok? ; true end
|
||||||
|
end
|
||||||
|
|
||||||
|
if ARGV[0].nil?
|
||||||
|
puts "You need to specify a file to upload."
|
||||||
|
exit!(1)
|
||||||
|
end
|
||||||
|
|
||||||
|
CloudApp.authenticate(email,password)
|
||||||
|
url = CloudApp::Item.create(:upload, {:file => ARGV[0]}).url
|
||||||
|
|
||||||
|
# Say it for good measure.
|
||||||
|
puts "Uploaded to #{url}."
|
||||||
|
|
||||||
|
# Get the embed link.
|
||||||
|
url = "#{url}/#{ARGV[0].split('/').last}"
|
||||||
|
|
||||||
|
# Copy it to your (Mac's) clipboard.
|
||||||
|
`echo '#{url}' | tr -d "\n" | pbcopy`
|
20
plugins/compleat/compleat.plugin.zsh
Normal file
20
plugins/compleat/compleat.plugin.zsh
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
# ------------------------------------------------------------------------------
|
||||||
|
# FILE: compleat.plugin.zsh
|
||||||
|
# DESCRIPTION: oh-my-zsh plugin file.
|
||||||
|
# AUTHOR: Sorin Ionescu (sorin.ionescu@gmail.com)
|
||||||
|
# VERSION: 1.0.0
|
||||||
|
# ------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
if (( ${+commands[compleat]} )); then
|
||||||
|
local prefix="${commands[compleat]:h:h}"
|
||||||
|
local setup="${prefix}/share/compleat-1.0/compleat_setup"
|
||||||
|
|
||||||
|
if [[ -f "$setup" ]]; then
|
||||||
|
if ! bashcompinit >/dev/null 2>&1; then
|
||||||
|
autoload -U bashcompinit
|
||||||
|
bashcompinit -i
|
||||||
|
fi
|
||||||
|
|
||||||
|
source "$setup"
|
||||||
|
fi
|
||||||
|
fi
|
222
plugins/django/django.plugin.zsh
Normal file
222
plugins/django/django.plugin.zsh
Normal file
|
@ -0,0 +1,222 @@
|
||||||
|
#compdef manage.py
|
||||||
|
|
||||||
|
typeset -ga nul_args
|
||||||
|
nul_args=(
|
||||||
|
'--settings=-[the Python path to a settings module.]:file:_files'
|
||||||
|
'--pythonpath=-[a directory to add to the Python path.]::directory:_directories'
|
||||||
|
'--traceback[print traceback on exception.]'
|
||||||
|
"--version[show program's version number and exit.]"
|
||||||
|
{-h,--help}'[show this help message and exit.]'
|
||||||
|
)
|
||||||
|
|
||||||
|
_managepy-adminindex(){
|
||||||
|
_arguments -s : \
|
||||||
|
$nul_args \
|
||||||
|
'*::directory:_directories' && ret=0
|
||||||
|
}
|
||||||
|
|
||||||
|
_managepy-createcachetable(){
|
||||||
|
_arguments -s : \
|
||||||
|
$nul_args && ret=0
|
||||||
|
}
|
||||||
|
|
||||||
|
_managepy-dbshell(){
|
||||||
|
_arguments -s : \
|
||||||
|
$nul_args && ret=0
|
||||||
|
}
|
||||||
|
|
||||||
|
_managepy-diffsettings(){
|
||||||
|
_arguments -s : \
|
||||||
|
$nul_args && ret=0
|
||||||
|
}
|
||||||
|
|
||||||
|
_managepy-dumpdata(){
|
||||||
|
_arguments -s : \
|
||||||
|
'--format=-[specifies the output serialization format for fixtures.]:format:(json yaml xml)' \
|
||||||
|
'--indent=-[specifies the indent level to use when pretty-printing output.]:' \
|
||||||
|
$nul_args \
|
||||||
|
'*::appname:_applist' && ret=0
|
||||||
|
}
|
||||||
|
|
||||||
|
_managepy-flush(){
|
||||||
|
_arguments -s : \
|
||||||
|
'--verbosity=-[verbosity level; 0=minimal output, 1=normal output, 2=all output.]:Verbosity:((0\:minimal 1\:normal 2\:all))' \
|
||||||
|
'--noinput[tells Django to NOT prompt the user for input of any kind.]' \
|
||||||
|
$nul_args && ret=0
|
||||||
|
}
|
||||||
|
|
||||||
|
_managepy-help(){
|
||||||
|
_arguments -s : \
|
||||||
|
'*:command:_managepy_cmds' \
|
||||||
|
$nul_args && ret=0
|
||||||
|
}
|
||||||
|
|
||||||
|
_managepy_cmds(){
|
||||||
|
local line
|
||||||
|
local -a cmd
|
||||||
|
_call_program help-command ./manage.py help \
|
||||||
|
|& sed -n '/^ /s/[(), ]/ /gp' \
|
||||||
|
| while read -A line; do cmd=($line $cmd) done
|
||||||
|
_describe -t managepy-command 'manage.py command' cmd
|
||||||
|
}
|
||||||
|
|
||||||
|
_managepy-inspectdb(){
|
||||||
|
_arguments -s : \
|
||||||
|
$nul_args && ret=0
|
||||||
|
}
|
||||||
|
|
||||||
|
_managepy-loaddata(){
|
||||||
|
_arguments -s : \
|
||||||
|
'--verbosity=-[verbosity level; 0=minimal output, 1=normal output, 2=all output.]:Verbosity:((0\:minimal 1\:normal 2\:all))' \
|
||||||
|
'*::file:_files' \
|
||||||
|
$nul_args && ret=0
|
||||||
|
}
|
||||||
|
|
||||||
|
_managepy-reset(){
|
||||||
|
_arguments -s : \
|
||||||
|
'--noinput[tells Django to NOT prompt the user for input of any kind.]' \
|
||||||
|
'*::appname:_applist' \
|
||||||
|
$nul_args && ret=0
|
||||||
|
}
|
||||||
|
|
||||||
|
_managepy-runfcgi(){
|
||||||
|
local state
|
||||||
|
|
||||||
|
local fcgi_opts
|
||||||
|
fcgi_opts=(
|
||||||
|
'protocol[fcgi, scgi, ajp, ... (default fcgi)]:protocol:(fcgi scgi ajp)'
|
||||||
|
'host[hostname to listen on..]:'
|
||||||
|
'port[port to listen on.]:'
|
||||||
|
'socket[UNIX socket to listen on.]::file:_files'
|
||||||
|
'method[prefork or threaded (default prefork)]:method:(prefork threaded)'
|
||||||
|
'maxrequests[number of requests a child handles before it is killed and a new child is forked (0 = no limit).]:'
|
||||||
|
'maxspare[max number of spare processes / threads.]:'
|
||||||
|
'minspare[min number of spare processes / threads.]:'
|
||||||
|
'maxchildren[hard limit number of processes / threads.]:'
|
||||||
|
'daemonize[whether to detach from terminal.]:boolean:(False True)'
|
||||||
|
'pidfile[write the spawned process-id to this file.]:file:_files'
|
||||||
|
'workdir[change to this directory when daemonizing.]:directory:_files'
|
||||||
|
'outlog[write stdout to this file.]:file:_files'
|
||||||
|
'errlog[write stderr to this file.]:file:_files'
|
||||||
|
)
|
||||||
|
|
||||||
|
_arguments -s : \
|
||||||
|
$nul_args \
|
||||||
|
'*: :_values "FCGI Setting" $fcgi_opts' && ret=0
|
||||||
|
}
|
||||||
|
|
||||||
|
_managepy-runserver(){
|
||||||
|
_arguments -s : \
|
||||||
|
'--noreload[tells Django to NOT use the auto-reloader.]' \
|
||||||
|
'--adminmedia[specifies the directory from which to serve admin media.]:directory:_files' \
|
||||||
|
$nul_args && ret=0
|
||||||
|
}
|
||||||
|
|
||||||
|
_managepy-shell(){
|
||||||
|
_arguments -s : \
|
||||||
|
'--plain[tells Django to use plain Python, not IPython.]' \
|
||||||
|
$nul_args && ret=0
|
||||||
|
}
|
||||||
|
|
||||||
|
_managepy-sql(){}
|
||||||
|
_managepy-sqlall(){}
|
||||||
|
_managepy-sqlclear(){}
|
||||||
|
_managepy-sqlcustom(){}
|
||||||
|
_managepy-sqlflush(){}
|
||||||
|
_managepy-sqlindexes(){}
|
||||||
|
_managepy-sqlinitialdata(){}
|
||||||
|
_managepy-sqlreset(){}
|
||||||
|
_managepy-sqlsequencereset(){}
|
||||||
|
_managepy-startapp(){}
|
||||||
|
|
||||||
|
_managepy-syncdb() {
|
||||||
|
_arguments -s : \
|
||||||
|
'--verbosity=-[verbosity level; 0=minimal output, 1=normal output, 2=all output.]:Verbosity:((0\:minimal 1\:normal 2\:all))' \
|
||||||
|
'--noinput[tells Django to NOT prompt the user for input of any kind.]' \
|
||||||
|
$nul_args && ret=0
|
||||||
|
}
|
||||||
|
|
||||||
|
_managepy-test() {
|
||||||
|
_arguments -s : \
|
||||||
|
'--verbosity=-[verbosity level; 0=minimal output, 1=normal output, 2=all output.]:Verbosity:((0\:minimal 1\:normal 2\:all))' \
|
||||||
|
'--noinput[tells Django to NOT prompt the user for input of any kind.]' \
|
||||||
|
'*::appname:_applist' \
|
||||||
|
$nul_args && ret=0
|
||||||
|
}
|
||||||
|
|
||||||
|
_managepy-testserver() {
|
||||||
|
_arguments -s : \
|
||||||
|
'--verbosity=-[verbosity level; 0=minimal output, 1=normal output, 2=all output.]:Verbosity:((0\:minimal 1\:normal 2\:all))' \
|
||||||
|
'--addrport=-[port number or ipaddr:port to run the server on.]' \
|
||||||
|
'*::fixture:_files' \
|
||||||
|
$nul_args && ret=0
|
||||||
|
}
|
||||||
|
|
||||||
|
_managepy-validate() {
|
||||||
|
_arguments -s : \
|
||||||
|
$nul_args && ret=0
|
||||||
|
}
|
||||||
|
|
||||||
|
_managepy-commands() {
|
||||||
|
local -a commands
|
||||||
|
|
||||||
|
commands=(
|
||||||
|
'adminindex:prints the admin-index template snippet for the given app name(s).'
|
||||||
|
'createcachetable:creates the table needed to use the SQL cache backend.'
|
||||||
|
'dbshell:runs the command-line client for the current DATABASE_ENGINE.'
|
||||||
|
"diffsettings:displays differences between the current settings.py and Django's default settings."
|
||||||
|
'dumpdata:Output the contents of the database as a fixture of the given format.'
|
||||||
|
'flush:Executes ``sqlflush`` on the current database.'
|
||||||
|
'help:manage.py help.'
|
||||||
|
'inspectdb:Introspects the database tables in the given database and outputs a Django model module.'
|
||||||
|
'loaddata:Installs the named fixture(s) in the database.'
|
||||||
|
'reset:Executes ``sqlreset`` for the given app(s) in the current database.'
|
||||||
|
'runfcgi:Run this project as a fastcgi (or some other protocol supported by flup) application,'
|
||||||
|
'runserver:Starts a lightweight Web server for development.'
|
||||||
|
'shell:Runs a Python interactive interpreter.'
|
||||||
|
'sql:Prints the CREATE TABLE SQL statements for the given app name(s).'
|
||||||
|
'sqlall:Prints the CREATE TABLE, custom SQL and CREATE INDEX SQL statements for the given model module name(s).'
|
||||||
|
'sqlclear:Prints the DROP TABLE SQL statements for the given app name(s).'
|
||||||
|
'sqlcustom:Prints the custom table modifying SQL statements for the given app name(s).'
|
||||||
|
'sqlflush:Returns a list of the SQL statements required to return all tables in the database to the state they were in just after they were installed.'
|
||||||
|
'sqlindexes:Prints the CREATE INDEX SQL statements for the given model module name(s).'
|
||||||
|
"sqlinitialdata:RENAMED: see 'sqlcustom'"
|
||||||
|
'sqlreset:Prints the DROP TABLE SQL, then the CREATE TABLE SQL, for the given app name(s).'
|
||||||
|
'sqlsequencereset:Prints the SQL statements for resetting sequences for the given app name(s).'
|
||||||
|
"startapp:Creates a Django app directory structure for the given app name in this project's directory."
|
||||||
|
"syncdb:Create the database tables for all apps in INSTALLED_APPS whose tables haven't already been created."
|
||||||
|
'test:Runs the test suite for the specified applications, or the entire site if no apps are specified.'
|
||||||
|
'testserver:Runs a development server with data from the given fixture(s).'
|
||||||
|
'validate:Validates all installed models.'
|
||||||
|
)
|
||||||
|
|
||||||
|
_describe -t commands 'manage.py command' commands && ret=0
|
||||||
|
}
|
||||||
|
|
||||||
|
_applist() {
|
||||||
|
local line
|
||||||
|
local -a apps
|
||||||
|
_call_program help-command "python -c \"import os.path as op, re, django.conf, sys;\\
|
||||||
|
bn=op.basename(op.abspath(op.curdir));[sys\\
|
||||||
|
.stdout.write(str(re.sub(r'^%s\.(.*?)$' %
|
||||||
|
bn, r'\1', i)) + '\n') for i in django.conf.settings.\\
|
||||||
|
INSTALLED_APPS if re.match(r'^%s' % bn, i)]\"" \
|
||||||
|
| while read -A line; do apps=($line $apps) done
|
||||||
|
_values 'Application' $apps && ret=0
|
||||||
|
}
|
||||||
|
|
||||||
|
_managepy() {
|
||||||
|
local curcontext=$curcontext ret=1
|
||||||
|
|
||||||
|
if ((CURRENT == 2)); then
|
||||||
|
_managepy-commands
|
||||||
|
else
|
||||||
|
shift words
|
||||||
|
(( CURRENT -- ))
|
||||||
|
curcontext="${curcontext%:*:*}:managepy-$words[1]:"
|
||||||
|
_call_function ret _managepy-$words[1]
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
compdef _managepy manage.py
|
||||||
|
compdef _managepy django
|
8
plugins/extract/_extract
Normal file
8
plugins/extract/_extract
Normal file
|
@ -0,0 +1,8 @@
|
||||||
|
#compdef extract
|
||||||
|
#autoload
|
||||||
|
|
||||||
|
_arguments \
|
||||||
|
'(-r --remove)'{-r,--remove}'[Remove archive.]' \
|
||||||
|
"*::archive file:_files -g '(#i)*.(tar|tgz|tbz|tbz2|txz|tlz|gz|bz2|xz|lzma|Z|zip|rar|7z|deb)(-.)'" && return 0
|
||||||
|
|
||||||
|
|
85
plugins/extract/extract.plugin.zsh
Normal file
85
plugins/extract/extract.plugin.zsh
Normal file
|
@ -0,0 +1,85 @@
|
||||||
|
# ------------------------------------------------------------------------------
|
||||||
|
# FILE: extract.plugin.zsh
|
||||||
|
# DESCRIPTION: oh-my-zsh plugin file.
|
||||||
|
# AUTHOR: Sorin Ionescu (sorin.ionescu@gmail.com)
|
||||||
|
# VERSION: 1.0.1
|
||||||
|
# ------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
|
||||||
|
function extract() {
|
||||||
|
local remove_archive
|
||||||
|
local success
|
||||||
|
local file_name
|
||||||
|
local extract_dir
|
||||||
|
|
||||||
|
if (( $# == 0 )); then
|
||||||
|
echo "Usage: extract [-option] [file ...]"
|
||||||
|
echo
|
||||||
|
echo Options:
|
||||||
|
echo " -r, --remove Remove archive."
|
||||||
|
echo
|
||||||
|
echo "Report bugs to <sorin.ionescu@gmail.com>."
|
||||||
|
fi
|
||||||
|
|
||||||
|
remove_archive=1
|
||||||
|
if [[ "$1" == "-r" ]] || [[ "$1" == "--remove" ]]; then
|
||||||
|
remove_archive=0
|
||||||
|
shift
|
||||||
|
fi
|
||||||
|
|
||||||
|
while (( $# > 0 )); do
|
||||||
|
if [[ ! -f "$1" ]]; then
|
||||||
|
echo "extract: '$1' is not a valid file" 1>&2
|
||||||
|
shift
|
||||||
|
continue
|
||||||
|
fi
|
||||||
|
|
||||||
|
success=0
|
||||||
|
file_name="$( basename "$1" )"
|
||||||
|
extract_dir="$( echo "$file_name" | sed "s/\.${1##*.}//g" )"
|
||||||
|
case "$1" in
|
||||||
|
(*.tar.gz|*.tgz) tar xvzf "$1" ;;
|
||||||
|
(*.tar.bz2|*.tbz|*.tbz2) tar xvjf "$1" ;;
|
||||||
|
(*.tar.xz|*.txz) tar --xz --help &> /dev/null \
|
||||||
|
&& tar --xz -xvf "$1" \
|
||||||
|
|| xzcat "$1" | tar xvf - ;;
|
||||||
|
(*.tar.zma|*.tlz) tar --lzma --help &> /dev/null \
|
||||||
|
&& tar --lzma -xvf "$1" \
|
||||||
|
|| lzcat "$1" | tar xvf - ;;
|
||||||
|
(*.tar) tar xvf "$1" ;;
|
||||||
|
(*.gz) gunzip "$1" ;;
|
||||||
|
(*.bz2) bunzip2 "$1" ;;
|
||||||
|
(*.xz) unxz "$1" ;;
|
||||||
|
(*.lzma) unlzma "$1" ;;
|
||||||
|
(*.Z) uncompress "$1" ;;
|
||||||
|
(*.zip) unzip "$1" -d $extract_dir ;;
|
||||||
|
(*.rar) unrar e -ad "$1" ;;
|
||||||
|
(*.7z) 7za x "$1" ;;
|
||||||
|
(*.deb)
|
||||||
|
mkdir -p "$extract_dir/control"
|
||||||
|
mkdir -p "$extract_dir/data"
|
||||||
|
cd "$extract_dir"; ar vx "../${1}" > /dev/null
|
||||||
|
cd control; tar xzvf ../control.tar.gz
|
||||||
|
cd ../data; tar xzvf ../data.tar.gz
|
||||||
|
cd ..; rm *.tar.gz debian-binary
|
||||||
|
cd ..
|
||||||
|
;;
|
||||||
|
(*)
|
||||||
|
echo "extract: '$1' cannot be extracted" 1>&2
|
||||||
|
success=1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
(( success = $success > 0 ? $success : $? ))
|
||||||
|
(( $success == 0 )) && (( $remove_archive == 0 )) && rm "$1"
|
||||||
|
shift
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
alias x=extract
|
||||||
|
|
||||||
|
# add extract completion function to path
|
||||||
|
fpath=($ZSH/plugins/extract $fpath)
|
||||||
|
autoload -U compinit
|
||||||
|
compinit -i
|
||||||
|
|
34
plugins/gas/_gas
Normal file
34
plugins/gas/_gas
Normal file
|
@ -0,0 +1,34 @@
|
||||||
|
#compdef gas
|
||||||
|
|
||||||
|
local curcontext="$curcontext" state line cmds ret=1
|
||||||
|
|
||||||
|
_arguments -C \
|
||||||
|
'(- 1 *)'{-v,--version}'[display version information]' \
|
||||||
|
'(-h|--help)'{-h,--help}'[show help information]' \
|
||||||
|
'1: :->cmds' \
|
||||||
|
'*: :->args' && ret=0
|
||||||
|
|
||||||
|
case $state in
|
||||||
|
cmds)
|
||||||
|
cmds=(
|
||||||
|
"version:Prints Gas's version"
|
||||||
|
"use:Uses author"
|
||||||
|
"show:Shows your current user"
|
||||||
|
"list:Lists your authors"
|
||||||
|
"import:Imports current user to gasconfig"
|
||||||
|
"help:Describe available tasks or one specific task"
|
||||||
|
"delete:Deletes author"
|
||||||
|
"add:Adds author to gasconfig"
|
||||||
|
)
|
||||||
|
_describe -t commands 'gas command' cmds && ret=0
|
||||||
|
;;
|
||||||
|
args)
|
||||||
|
case $line[1] in
|
||||||
|
(use|delete)
|
||||||
|
_values -S , 'authors' $(cat ~/.gas | sed -n -e 's/^\[\(.*\)\]/\1/p') && ret=0
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
return ret
|
|
@ -27,11 +27,19 @@ alias gcp='git cherry-pick'
|
||||||
compdef _git gcp=git-cherry-pick
|
compdef _git gcp=git-cherry-pick
|
||||||
alias glg='git log --stat --max-count=5'
|
alias glg='git log --stat --max-count=5'
|
||||||
compdef _git glg=git-log
|
compdef _git glg=git-log
|
||||||
|
alias glgg='git log --graph --max-count=5'
|
||||||
|
compdef _git glgg=git-log
|
||||||
|
alias gss='git status -s'
|
||||||
|
compdef _git gss=git-status
|
||||||
|
alias ga='git add'
|
||||||
|
compdef _git ga=git-add
|
||||||
|
|
||||||
# Git and svn mix
|
# Git and svn mix
|
||||||
alias git-svn-dcommit-push='git svn dcommit && git push github master:svntrunk'
|
alias git-svn-dcommit-push='git svn dcommit && git push github master:svntrunk'
|
||||||
compdef git-svn-dcommit-push=git
|
compdef git-svn-dcommit-push=git
|
||||||
|
|
||||||
|
alias gsr='git svn rebase'
|
||||||
|
alias gsd='git svn dcommit'
|
||||||
#
|
#
|
||||||
# Will return the current branch name
|
# Will return the current branch name
|
||||||
# Usage example: git pull origin $(current_branch)
|
# Usage example: git pull origin $(current_branch)
|
||||||
|
|
|
@ -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
|
||||||
|
|
||||||
|
|
26
plugins/gpg-agent/gpg-agent.plugin.zsh
Normal file
26
plugins/gpg-agent/gpg-agent.plugin.zsh
Normal file
|
@ -0,0 +1,26 @@
|
||||||
|
# Based on ssh-agent code
|
||||||
|
|
||||||
|
local GPG_ENV=$HOME/.gnupg/gpg-agent.env
|
||||||
|
|
||||||
|
function start_agent {
|
||||||
|
/usr/bin/env gpg-agent --daemon --enable-ssh-support --write-env-file ${GPG_ENV} > /dev/null
|
||||||
|
chmod 600 ${GPG_ENV}
|
||||||
|
. ${GPG_ENV} > /dev/null
|
||||||
|
}
|
||||||
|
|
||||||
|
# Source GPG agent settings, if applicable
|
||||||
|
if [ -f "${GPG_ENV}" ]; then
|
||||||
|
. ${GPG_ENV} > /dev/null
|
||||||
|
ps -ef | grep ${SSH_AGENT_PID} | grep gpg-agent > /dev/null || {
|
||||||
|
start_agent;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
start_agent;
|
||||||
|
fi
|
||||||
|
|
||||||
|
export GPG_AGENT_INFO
|
||||||
|
export SSH_AUTH_SOCK
|
||||||
|
export SSH_AGENT_PID
|
||||||
|
|
||||||
|
GPG_TTY=$(tty)
|
||||||
|
export GPG_TTY
|
158
plugins/heroku/_heroku
Normal file
158
plugins/heroku/_heroku
Normal file
|
@ -0,0 +1,158 @@
|
||||||
|
#compdef heroku
|
||||||
|
|
||||||
|
# Heroku Autocomplete plugin for Oh-My-Zsh
|
||||||
|
# Requires: The Heroku client gem (https://github.com/heroku/heroku)
|
||||||
|
# Author: Ali B. (http://awhitebox.com)
|
||||||
|
|
||||||
|
local -a _1st_arguments
|
||||||
|
_1st_arguments=(
|
||||||
|
"account\:confirm_billing":"Confirm that your account can be billed at the end of the month"
|
||||||
|
"addons":"list installed addons"
|
||||||
|
"addons\:list":"list all available addons"
|
||||||
|
"addons\:add":"install an addon"
|
||||||
|
"addons\:upgrade":"upgrade an existing addon"
|
||||||
|
"addons\:downgrade":"downgrade an existing addon"
|
||||||
|
"addons\:remove":"uninstall an addon"
|
||||||
|
"addons\:open":"open an addon's dashboard in your browser"
|
||||||
|
"apps":"list your apps"
|
||||||
|
"apps\:info":"show detailed app information"
|
||||||
|
"apps\:create":"create a new app"
|
||||||
|
"apps\:rename":"rename the app"
|
||||||
|
"apps\:open":"open the app in a web browser"
|
||||||
|
"apps\:destroy":"permanently destroy an app"
|
||||||
|
"auth\:login":"log in with your heroku credentials"
|
||||||
|
"auth\:logout":"clear local authentication credentials"
|
||||||
|
"config":"display the config vars for an app"
|
||||||
|
"config\:add":"add one or more config vars"
|
||||||
|
"config\:remove":"remove a config var"
|
||||||
|
"db\:push":"push local data up to your app"
|
||||||
|
"db\:pull":"pull heroku data down into your local database"
|
||||||
|
"domains":"list custom domains for an app"
|
||||||
|
"domains\:add":"add a custom domain to an app"
|
||||||
|
"domains\:remove":"remove a custom domain from an app"
|
||||||
|
"domains\:clear":"remove all custom domains from an app"
|
||||||
|
"help":"list available commands or display help for a specific command"
|
||||||
|
"keys":"display keys for the current user"
|
||||||
|
"keys\:add":"add a key for the current user"
|
||||||
|
"keys\:remove":"remove a key from the current user"
|
||||||
|
"keys\:clear":"remove all authentication keys from the current user"
|
||||||
|
"logs":"display recent log output"
|
||||||
|
"logs\:cron":"DEPRECATED: display cron logs from legacy logging"
|
||||||
|
"logs\:drains":"manage syslog drains"
|
||||||
|
"maintenance\:on":"put the app into maintenance mode"
|
||||||
|
"maintenance\:off":"take the app out of maintenance mode"
|
||||||
|
"pg\:info":"display database information"
|
||||||
|
"pg\:ingress":"allow direct connections to the database from this IP for one minute"
|
||||||
|
"pg\:promote":"sets DATABASE as your DATABASE_URL"
|
||||||
|
"pg\:psql":"open a psql shell to the database"
|
||||||
|
"pg\:reset":"delete all data in DATABASE"
|
||||||
|
"pg\:unfollow":"stop a replica from following and make it a read/write database"
|
||||||
|
"pg\:wait":"monitor database creation, exit when complete"
|
||||||
|
"pgbackups":"list captured backups"
|
||||||
|
"pgbackups\:url":"get a temporary URL for a backup"
|
||||||
|
"pgbackups\:capture":"capture a backup from a database id"
|
||||||
|
"pgbackups\:restore":"restore a backup to a database"
|
||||||
|
"pgbackups\:destroy":"destroys a backup"
|
||||||
|
"plugins":"list installed plugins"
|
||||||
|
"plugins\:install":"install a plugin"
|
||||||
|
"plugins\:uninstall":"uninstall a plugin"
|
||||||
|
"ps\:dynos":"scale to QTY web processes"
|
||||||
|
"ps\:workers":"scale to QTY background processes"
|
||||||
|
"ps":"list processes for an app"
|
||||||
|
"ps\:restart":"restart an app process"
|
||||||
|
"ps\:scale":"scale processes by the given amount"
|
||||||
|
"releases":"list releases"
|
||||||
|
"releases\:info":"view detailed information for a release"
|
||||||
|
"rollback":"roll back to an older release"
|
||||||
|
"run":"run an attached process"
|
||||||
|
"run\:rake":"remotely execute a rake command"
|
||||||
|
"run\:console":"open a remote console session"
|
||||||
|
"sharing":"list collaborators on an app"
|
||||||
|
"sharing\:add":"add a collaborator to an app"
|
||||||
|
"sharing\:remove":"remove a collaborator from an app"
|
||||||
|
"sharing\:transfer":"transfer an app to a new owner"
|
||||||
|
"ssl":"list certificates for an app"
|
||||||
|
"ssl\:add":"add an ssl certificate to an app"
|
||||||
|
"ssl\:remove":"remove an ssl certificate from an app"
|
||||||
|
"ssl\:clear":"remove all ssl certificates from an app"
|
||||||
|
"stack":"show the list of available stacks"
|
||||||
|
"stack\:migrate":"prepare migration of this app to a new stack"
|
||||||
|
"version":"show heroku client version"
|
||||||
|
)
|
||||||
|
|
||||||
|
_arguments '*:: :->command'
|
||||||
|
|
||||||
|
if (( CURRENT == 1 )); then
|
||||||
|
_describe -t commands "heroku command" _1st_arguments
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
local -a _command_args
|
||||||
|
case "$words[1]" in
|
||||||
|
apps:info)
|
||||||
|
_command_args=(
|
||||||
|
'(-r|--raw)'{-r,--raw}'[output info as raw key/value pairs]' \
|
||||||
|
)
|
||||||
|
;;
|
||||||
|
apps:create)
|
||||||
|
_command_args=(
|
||||||
|
'(-a|--addons)'{-a,--addons}'[a list of addons to install]' \
|
||||||
|
'(-r|--remote)'{-r,--remote}'[the git remote to create, default "heroku"]' \
|
||||||
|
'(-s|--stack)'{-s,--stack}'[the stack on which to create the app]' \
|
||||||
|
)
|
||||||
|
;;
|
||||||
|
config)
|
||||||
|
_command_args=(
|
||||||
|
'(-s|--shell)'{-s,--shell}'[output config vars in shell format]' \
|
||||||
|
)
|
||||||
|
;;
|
||||||
|
db:push)
|
||||||
|
_command_args=(
|
||||||
|
'(-c|--chunksize)'{-c,--chunksize}'[specify the number of rows to send in each batch]' \
|
||||||
|
'(-d|--debug)'{-d,--debug}'[enable debugging output]' \
|
||||||
|
'(-e|--exclude)'{-e,--exclude}'[exclude the specified tables from the push]' \
|
||||||
|
'(-f|--filter)'{-f,--filter}'[only push certain tables]' \
|
||||||
|
'(-r|--resume)'{-r,--resume}'[resume transfer described by a .dat file]' \
|
||||||
|
'(-t|--tables)'{-t,--tables}'[only push the specified tables]' \
|
||||||
|
)
|
||||||
|
;;
|
||||||
|
db:pull)
|
||||||
|
_command_args=(
|
||||||
|
'(-c|--chunksize)'{-c,--chunksize}'[specify the number of rows to send in each batch]' \
|
||||||
|
'(-d|--debug)'{-d,--debug}'[enable debugging output]' \
|
||||||
|
'(-e|--exclude)'{-e,--exclude}'[exclude the specified tables from the pull]' \
|
||||||
|
'(-f|--filter)'{-f,--filter}'[only pull certain tables]' \
|
||||||
|
'(-r|--resume)'{-r,--resume}'[resume transfer described by a .dat file]' \
|
||||||
|
'(-t|--tables)'{-t,--tables}'[only pull the specified tables]' \
|
||||||
|
)
|
||||||
|
;;
|
||||||
|
keys)
|
||||||
|
_command_args=(
|
||||||
|
'(-l|--long)'{-l,--long}'[display extended information for each key]' \
|
||||||
|
)
|
||||||
|
;;
|
||||||
|
logs)
|
||||||
|
_command_args=(
|
||||||
|
'(-n|--num)'{-n,--num}'[the number of lines to display]' \
|
||||||
|
'(-p|--ps)'{-p,--ps}'[only display logs from the given process]' \
|
||||||
|
'(-s|--source)'{-s,--source}'[only display logs from the given source]' \
|
||||||
|
'(-t|--tail)'{-t,--tail}'[continually stream logs]' \
|
||||||
|
)
|
||||||
|
;;
|
||||||
|
pgbackups:capture)
|
||||||
|
_command_args=(
|
||||||
|
'(-e|--expire)'{-e,--expire}'[if no slots are available to capture, delete the oldest backup to make room]' \
|
||||||
|
)
|
||||||
|
;;
|
||||||
|
stack)
|
||||||
|
_command_args=(
|
||||||
|
'(-a|--all)'{-a,--all}'[include deprecated stacks]' \
|
||||||
|
)
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
_arguments \
|
||||||
|
$_command_args \
|
||||||
|
'(--app)--app[the app name]' \
|
||||||
|
&& return 0
|
||||||
|
|
7
plugins/history-substring-search/README
Normal file
7
plugins/history-substring-search/README
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
To activate this script, load it into an interactive ZSH session:
|
||||||
|
|
||||||
|
% source history-substring-search.zsh
|
||||||
|
|
||||||
|
See the "history-substring-search.zsh" file for more information:
|
||||||
|
|
||||||
|
% sed -n '2,/^$/s/^#//p' history-substring-search.zsh | more
|
|
@ -0,0 +1,12 @@
|
||||||
|
# This file integrates the history-substring-search script into oh-my-zsh.
|
||||||
|
|
||||||
|
source "$ZSH/plugins/history-substring-search/history-substring-search.zsh"
|
||||||
|
|
||||||
|
if test "$CASE_SENSITIVE" = true; then
|
||||||
|
unset HISTORY_SUBSTRING_SEARCH_GLOBBING_FLAGS
|
||||||
|
fi
|
||||||
|
|
||||||
|
if test "$DISABLE_COLOR" = true; then
|
||||||
|
unset HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_FOUND
|
||||||
|
unset HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_NOT_FOUND
|
||||||
|
fi
|
642
plugins/history-substring-search/history-substring-search.zsh
Normal file
642
plugins/history-substring-search/history-substring-search.zsh
Normal file
|
@ -0,0 +1,642 @@
|
||||||
|
#!/usr/bin/env zsh
|
||||||
|
#
|
||||||
|
# This is a clean-room implementation of the Fish[1] shell's history search
|
||||||
|
# feature, where you can type in any part of any previously entered command
|
||||||
|
# and press the UP and DOWN arrow keys to cycle through the matching commands.
|
||||||
|
#
|
||||||
|
#-----------------------------------------------------------------------------
|
||||||
|
# Usage
|
||||||
|
#-----------------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
# 1. Load this script into your interactive ZSH session:
|
||||||
|
#
|
||||||
|
# % source history-substring-search.zsh
|
||||||
|
#
|
||||||
|
# If you want to use the zsh-syntax-highlighting[6] script along with this
|
||||||
|
# script, then make sure that you load it *before* you load this script:
|
||||||
|
#
|
||||||
|
# % source zsh-syntax-highlighting.zsh
|
||||||
|
# % source history-substring-search.zsh
|
||||||
|
#
|
||||||
|
# 2. Type any part of any previous command and then:
|
||||||
|
#
|
||||||
|
# * Press the UP arrow key to select the nearest command that (1) contains
|
||||||
|
# your query and (2) is older than the current command in the command
|
||||||
|
# history.
|
||||||
|
#
|
||||||
|
# * Press the DOWN arrow key to select the nearest command that (1)
|
||||||
|
# contains your query and (2) is newer than the current command in the
|
||||||
|
# command history.
|
||||||
|
#
|
||||||
|
# * Press ^U (the Control and U keys simultaneously) to abort the search.
|
||||||
|
#
|
||||||
|
# 3. If a matching command spans more than one line of text, press the LEFT
|
||||||
|
# arrow key to move the cursor away from the end of the command, and then:
|
||||||
|
#
|
||||||
|
# * Press the UP arrow key to move the cursor to the line above. When the
|
||||||
|
# cursor reaches the first line of the command, pressing the UP arrow
|
||||||
|
# key again will cause this script to perform another search.
|
||||||
|
#
|
||||||
|
# * Press the DOWN arrow key to move the cursor to the line below. When
|
||||||
|
# the cursor reaches the last line of the command, pressing the DOWN
|
||||||
|
# arrow key again will cause this script to perform another search.
|
||||||
|
#
|
||||||
|
#-----------------------------------------------------------------------------
|
||||||
|
# Configuration
|
||||||
|
#-----------------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
# This script defines the following global variables. You may override their
|
||||||
|
# default values only after having loaded this script into your ZSH session.
|
||||||
|
#
|
||||||
|
# * HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_FOUND is a global variable that defines
|
||||||
|
# how the query should be highlighted inside a matching command. Its default
|
||||||
|
# value causes this script to highlight using bold, white text on a magenta
|
||||||
|
# background. See the "Character Highlighting" section in the zshzle(1) man
|
||||||
|
# page to learn about the kinds of values you may assign to this variable.
|
||||||
|
#
|
||||||
|
# * HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_NOT_FOUND is a global variable that
|
||||||
|
# defines how the query should be highlighted when no commands in the
|
||||||
|
# history match it. Its default value causes this script to highlight using
|
||||||
|
# bold, white text on a red background. See the "Character Highlighting"
|
||||||
|
# section in the zshzle(1) man page to learn about the kinds of values you
|
||||||
|
# may assign to this variable.
|
||||||
|
#
|
||||||
|
# * HISTORY_SUBSTRING_SEARCH_GLOBBING_FLAGS is a global variable that defines
|
||||||
|
# how the command history will be searched for your query. Its default value
|
||||||
|
# causes this script to perform a case-insensitive search. See the "Globbing
|
||||||
|
# Flags" section in the zshexpn(1) man page to learn about the kinds of
|
||||||
|
# values you may assign to this variable.
|
||||||
|
#
|
||||||
|
#-----------------------------------------------------------------------------
|
||||||
|
# History
|
||||||
|
#-----------------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
# This script was originally written by Peter Stephenson[2], who published it
|
||||||
|
# to the ZSH users mailing list (thereby making it public domain) in September
|
||||||
|
# 2009. It was later revised by Guido van Steen and released under the BSD
|
||||||
|
# license (see below) as part of the fizsh[3] project in January 2011.
|
||||||
|
#
|
||||||
|
# It was later extracted from fizsh[3] release 1.0.1, refactored heavily, and
|
||||||
|
# repackaged as both an oh-my-zsh plugin[4] and as an independently loadable
|
||||||
|
# ZSH script[5] by Suraj N. Kurapati in 2011.
|
||||||
|
#
|
||||||
|
# It was further developed[4] by Guido van Steen, Suraj N. Kurapati, Sorin
|
||||||
|
# Ionescu, and Vincent Guerci in 2011.
|
||||||
|
#
|
||||||
|
# [1]: http://fishshell.com
|
||||||
|
# [2]: http://www.zsh.org/mla/users/2009/msg00818.html
|
||||||
|
# [3]: http://sourceforge.net/projects/fizsh/
|
||||||
|
# [4]: https://github.com/robbyrussell/oh-my-zsh/pull/215
|
||||||
|
# [5]: https://github.com/sunaku/zsh-history-substring-search
|
||||||
|
# [6]: https://github.com/nicoulaj/zsh-syntax-highlighting
|
||||||
|
#
|
||||||
|
##############################################################################
|
||||||
|
#
|
||||||
|
# Copyright (c) 2009 Peter Stephenson
|
||||||
|
# Copyright (c) 2011 Guido van Steen
|
||||||
|
# Copyright (c) 2011 Suraj N. Kurapati
|
||||||
|
# Copyright (c) 2011 Sorin Ionescu
|
||||||
|
# Copyright (c) 2011 Vincent Guerci
|
||||||
|
# All rights reserved.
|
||||||
|
#
|
||||||
|
# Redistribution and use in source and binary forms, with or without
|
||||||
|
# modification, are permitted provided that the following conditions are met:
|
||||||
|
#
|
||||||
|
# * Redistributions of source code must retain the above copyright
|
||||||
|
# notice, this list of conditions and the following disclaimer.
|
||||||
|
#
|
||||||
|
# * Redistributions in binary form must reproduce the above
|
||||||
|
# copyright notice, this list of conditions and the following
|
||||||
|
# disclaimer in the documentation and/or other materials provided
|
||||||
|
# with the distribution.
|
||||||
|
#
|
||||||
|
# * Neither the name of the FIZSH nor the names of its contributors
|
||||||
|
# may be used to endorse or promote products derived from this
|
||||||
|
# software without specific prior written permission.
|
||||||
|
#
|
||||||
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||||||
|
# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
# POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
#
|
||||||
|
##############################################################################
|
||||||
|
|
||||||
|
#-----------------------------------------------------------------------------
|
||||||
|
# configuration variables
|
||||||
|
#-----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_FOUND='bg=magenta,fg=white,bold'
|
||||||
|
HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_NOT_FOUND='bg=red,fg=white,bold'
|
||||||
|
HISTORY_SUBSTRING_SEARCH_GLOBBING_FLAGS='i'
|
||||||
|
|
||||||
|
#-----------------------------------------------------------------------------
|
||||||
|
# the main ZLE widgets
|
||||||
|
#-----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
function history-substring-search-up() {
|
||||||
|
_history-substring-search-begin
|
||||||
|
|
||||||
|
_history-substring-search-up-history ||
|
||||||
|
_history-substring-search-up-buffer ||
|
||||||
|
_history-substring-search-up-search
|
||||||
|
|
||||||
|
_history-substring-search-end
|
||||||
|
}
|
||||||
|
|
||||||
|
function history-substring-search-down() {
|
||||||
|
_history-substring-search-begin
|
||||||
|
|
||||||
|
_history-substring-search-down-history ||
|
||||||
|
_history-substring-search-down-buffer ||
|
||||||
|
_history-substring-search-down-search
|
||||||
|
|
||||||
|
_history-substring-search-end
|
||||||
|
}
|
||||||
|
|
||||||
|
zle -N history-substring-search-up
|
||||||
|
zle -N history-substring-search-down
|
||||||
|
|
||||||
|
bindkey '\e[A' history-substring-search-up
|
||||||
|
bindkey '\e[B' history-substring-search-down
|
||||||
|
|
||||||
|
#-----------------------------------------------------------------------------
|
||||||
|
# implementation details
|
||||||
|
#-----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
setopt extendedglob
|
||||||
|
zmodload -F zsh/parameter
|
||||||
|
|
||||||
|
#
|
||||||
|
# We have to "override" some keys and widgets if the
|
||||||
|
# zsh-syntax-highlighting plugin has not been loaded:
|
||||||
|
#
|
||||||
|
# https://github.com/nicoulaj/zsh-syntax-highlighting
|
||||||
|
#
|
||||||
|
if [[ $+functions[_zsh_highlight] -eq 0 ]]; then
|
||||||
|
#
|
||||||
|
# Dummy implementation of _zsh_highlight()
|
||||||
|
# that simply removes existing highlights
|
||||||
|
#
|
||||||
|
function _zsh_highlight() {
|
||||||
|
region_highlight=()
|
||||||
|
}
|
||||||
|
|
||||||
|
#
|
||||||
|
# Remove existing highlights when the user
|
||||||
|
# inserts printable characters into $BUFFER
|
||||||
|
#
|
||||||
|
function ordinary-key-press() {
|
||||||
|
if [[ $KEYS == [[:print:]] ]]; then
|
||||||
|
region_highlight=()
|
||||||
|
fi
|
||||||
|
zle .self-insert
|
||||||
|
}
|
||||||
|
zle -N self-insert ordinary-key-press
|
||||||
|
|
||||||
|
#
|
||||||
|
# Override ZLE widgets to invoke _zsh_highlight()
|
||||||
|
#
|
||||||
|
# https://github.com/nicoulaj/zsh-syntax-highlighting/blob/
|
||||||
|
# bb7fcb79fad797a40077bebaf6f4e4a93c9d8163/zsh-syntax-highlighting.zsh#L121
|
||||||
|
#
|
||||||
|
#--------------8<-------------------8<-------------------8<-----------------
|
||||||
|
#
|
||||||
|
# Copyright (c) 2010-2011 zsh-syntax-highlighting contributors
|
||||||
|
# All rights reserved.
|
||||||
|
#
|
||||||
|
# Redistribution and use in source and binary forms, with or without
|
||||||
|
# modification, are permitted provided that the following conditions are
|
||||||
|
# met:
|
||||||
|
#
|
||||||
|
# * Redistributions of source code must retain the above copyright
|
||||||
|
# notice, this list of conditions and the following disclaimer.
|
||||||
|
#
|
||||||
|
# * Redistributions in binary form must reproduce the above copyright
|
||||||
|
# notice, this list of conditions and the following disclaimer in the
|
||||||
|
# documentation and/or other materials provided with the distribution.
|
||||||
|
#
|
||||||
|
# * Neither the name of the zsh-syntax-highlighting contributors nor the
|
||||||
|
# names of its contributors may be used to endorse or promote products
|
||||||
|
# derived from this software without specific prior written permission.
|
||||||
|
#
|
||||||
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
|
||||||
|
# IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
|
||||||
|
# THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
||||||
|
# PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
|
||||||
|
# CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||||
|
# EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||||
|
# PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||||||
|
# PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
||||||
|
# LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||||
|
# NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
# SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
|
||||||
|
# Load ZSH module zsh/zleparameter, needed to override user defined widgets.
|
||||||
|
zmodload zsh/zleparameter 2>/dev/null || {
|
||||||
|
echo 'zsh-syntax-highlighting: failed loading zsh/zleparameter, exiting.' >&2
|
||||||
|
return -1
|
||||||
|
}
|
||||||
|
|
||||||
|
# Override ZLE widgets to make them invoke _zsh_highlight.
|
||||||
|
for event in ${${(f)"$(zle -la)"}:#(_*|orig-*|.run-help|.which-command)}; do
|
||||||
|
if [[ "$widgets[$event]" == completion:* ]]; then
|
||||||
|
eval "zle -C orig-$event ${${${widgets[$event]}#*:}/:/ } ; $event() { builtin zle orig-$event && _zsh_highlight } ; zle -N $event"
|
||||||
|
else
|
||||||
|
case $event in
|
||||||
|
accept-and-menu-complete)
|
||||||
|
eval "$event() { builtin zle .$event && _zsh_highlight } ; zle -N $event"
|
||||||
|
;;
|
||||||
|
|
||||||
|
# The following widgets should NOT remove any previously
|
||||||
|
# applied highlighting. Therefore we do not remap them.
|
||||||
|
.forward-char|.backward-char|.up-line-or-history|.down-line-or-history)
|
||||||
|
;;
|
||||||
|
|
||||||
|
.*)
|
||||||
|
clean_event=$event[2,${#event}] # Remove the leading dot in the event name
|
||||||
|
case ${widgets[$clean_event]-} in
|
||||||
|
(completion|user):*)
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
eval "$clean_event() { builtin zle $event && _zsh_highlight } ; zle -N $clean_event"
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
unset event clean_event
|
||||||
|
#-------------->8------------------->8------------------->8-----------------
|
||||||
|
fi
|
||||||
|
|
||||||
|
function _history-substring-search-begin() {
|
||||||
|
_history_substring_search_move_cursor_eol=false
|
||||||
|
_history_substring_search_query_highlight=
|
||||||
|
|
||||||
|
#
|
||||||
|
# Continue using the previous $_history_substring_search_result by default,
|
||||||
|
# unless the current query was cleared or a new/different query was entered.
|
||||||
|
#
|
||||||
|
if [[ -z $BUFFER || $BUFFER != $_history_substring_search_result ]]; then
|
||||||
|
#
|
||||||
|
# For the purpose of highlighting we will also keep
|
||||||
|
# a version without doubly-escaped meta characters.
|
||||||
|
#
|
||||||
|
_history_substring_search_query=$BUFFER
|
||||||
|
|
||||||
|
#
|
||||||
|
# $BUFFER contains the text that is in the command-line currently.
|
||||||
|
# we put an extra "\\" before meta characters such as "\(" and "\)",
|
||||||
|
# so that they become "\\\(" and "\\\)".
|
||||||
|
#
|
||||||
|
_history_substring_search_query_escaped=${BUFFER//(#m)[\][()|\\*?#<>~^]/\\$MATCH}
|
||||||
|
|
||||||
|
#
|
||||||
|
# Find all occurrences of the search query in the history file.
|
||||||
|
#
|
||||||
|
# (k) turns it an array of line numbers.
|
||||||
|
#
|
||||||
|
# (on) seems to remove duplicates, which are default
|
||||||
|
# options. They can be turned off by (ON).
|
||||||
|
#
|
||||||
|
_history_substring_search_matches=(${(kon)history[(R)(#$HISTORY_SUBSTRING_SEARCH_GLOBBING_FLAGS)*${_history_substring_search_query_escaped}*]})
|
||||||
|
|
||||||
|
#
|
||||||
|
# Define the range of values that $_history_substring_search_match_index
|
||||||
|
# can take: [0, $_history_substring_search_matches_count_plus].
|
||||||
|
#
|
||||||
|
_history_substring_search_matches_count=$#_history_substring_search_matches
|
||||||
|
_history_substring_search_matches_count_plus=$(( _history_substring_search_matches_count + 1 ))
|
||||||
|
_history_substring_search_matches_count_sans=$(( _history_substring_search_matches_count - 1 ))
|
||||||
|
|
||||||
|
#
|
||||||
|
# If $_history_substring_search_match_index is equal to
|
||||||
|
# $_history_substring_search_matches_count_plus, this indicates that we
|
||||||
|
# are beyond the beginning of $_history_substring_search_matches.
|
||||||
|
#
|
||||||
|
# If $_history_substring_search_match_index is equal to 0, this indicates
|
||||||
|
# that we are beyond the end of $_history_substring_search_matches.
|
||||||
|
#
|
||||||
|
# If we have initially pressed "up" we have to initialize
|
||||||
|
# $_history_substring_search_match_index to
|
||||||
|
# $_history_substring_search_matches_count_plus so that it will be
|
||||||
|
# decreased to $_history_substring_search_matches_count.
|
||||||
|
#
|
||||||
|
# If we have initially pressed "down" we have to initialize
|
||||||
|
# $_history_substring_search_match_index to
|
||||||
|
# $_history_substring_search_matches_count so that it will be increased to
|
||||||
|
# $_history_substring_search_matches_count_plus.
|
||||||
|
#
|
||||||
|
if [[ $WIDGET == history-substring-search-down ]]; then
|
||||||
|
_history_substring_search_match_index=$_history_substring_search_matches_count
|
||||||
|
else
|
||||||
|
_history_substring_search_match_index=$_history_substring_search_matches_count_plus
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
function _history-substring-search-end() {
|
||||||
|
_history_substring_search_result=$BUFFER
|
||||||
|
|
||||||
|
# move the cursor to the end of the command line
|
||||||
|
if [[ $_history_substring_search_move_cursor_eol == true ]]; then
|
||||||
|
CURSOR=${#BUFFER}
|
||||||
|
fi
|
||||||
|
|
||||||
|
# highlight command line using zsh-syntax-highlighting
|
||||||
|
_zsh_highlight
|
||||||
|
|
||||||
|
# highlight the search query inside the command line
|
||||||
|
if [[ -n $_history_substring_search_query_highlight && -n $_history_substring_search_query ]]; then
|
||||||
|
#
|
||||||
|
# The following expression yields a variable $MBEGIN, which
|
||||||
|
# indicates the begin position + 1 of the first occurrence
|
||||||
|
# of _history_substring_search_query_escaped in $BUFFER.
|
||||||
|
#
|
||||||
|
: ${(S)BUFFER##(#m$HISTORY_SUBSTRING_SEARCH_GLOBBING_FLAGS)($_history_substring_search_query##)}
|
||||||
|
local begin=$(( MBEGIN - 1 ))
|
||||||
|
local end=$(( begin + $#_history_substring_search_query ))
|
||||||
|
region_highlight+=("$begin $end $_history_substring_search_query_highlight")
|
||||||
|
fi
|
||||||
|
|
||||||
|
# For debugging purposes:
|
||||||
|
# zle -R "mn: "$_history_substring_search_match_index" m#: "${#_history_substring_search_matches}
|
||||||
|
# read -k -t 200 && zle -U $REPLY
|
||||||
|
|
||||||
|
# Exit successfully from the history-substring-search-* widgets.
|
||||||
|
true
|
||||||
|
}
|
||||||
|
|
||||||
|
function _history-substring-search-up-buffer() {
|
||||||
|
#
|
||||||
|
# Check if the UP arrow was pressed to move the cursor within a multi-line
|
||||||
|
# buffer. This amounts to three tests:
|
||||||
|
#
|
||||||
|
# 1. $#buflines -gt 1.
|
||||||
|
#
|
||||||
|
# 2. $CURSOR -ne $#BUFFER.
|
||||||
|
#
|
||||||
|
# 3. Check if we are on the first line of the current multi-line buffer.
|
||||||
|
# If so, pressing UP would amount to leaving the multi-line buffer.
|
||||||
|
#
|
||||||
|
# We check this by adding an extra "x" to $LBUFFER, which makes
|
||||||
|
# sure that xlbuflines is always equal to the number of lines
|
||||||
|
# until $CURSOR (including the line with the cursor on it).
|
||||||
|
#
|
||||||
|
local buflines XLBUFFER xlbuflines
|
||||||
|
buflines=(${(f)BUFFER})
|
||||||
|
XLBUFFER=$LBUFFER"x"
|
||||||
|
xlbuflines=(${(f)XLBUFFER})
|
||||||
|
|
||||||
|
if [[ $#buflines -gt 1 && $CURSOR -ne $#BUFFER && $#xlbuflines -ne 1 ]]; then
|
||||||
|
zle up-line-or-history
|
||||||
|
return true
|
||||||
|
fi
|
||||||
|
|
||||||
|
false
|
||||||
|
}
|
||||||
|
|
||||||
|
function _history-substring-search-down-buffer() {
|
||||||
|
#
|
||||||
|
# Check if the DOWN arrow was pressed to move the cursor within a multi-line
|
||||||
|
# buffer. This amounts to three tests:
|
||||||
|
#
|
||||||
|
# 1. $#buflines -gt 1.
|
||||||
|
#
|
||||||
|
# 2. $CURSOR -ne $#BUFFER.
|
||||||
|
#
|
||||||
|
# 3. Check if we are on the last line of the current multi-line buffer.
|
||||||
|
# If so, pressing DOWN would amount to leaving the multi-line buffer.
|
||||||
|
#
|
||||||
|
# We check this by adding an extra "x" to $RBUFFER, which makes
|
||||||
|
# sure that xrbuflines is always equal to the number of lines
|
||||||
|
# from $CURSOR (including the line with the cursor on it).
|
||||||
|
#
|
||||||
|
local buflines XRBUFFER xrbuflines
|
||||||
|
buflines=(${(f)BUFFER})
|
||||||
|
XRBUFFER="x"$RBUFFER
|
||||||
|
xrbuflines=(${(f)XRBUFFER})
|
||||||
|
|
||||||
|
if [[ $#buflines -gt 1 && $CURSOR -ne $#BUFFER && $#xrbuflines -ne 1 ]]; then
|
||||||
|
zle down-line-or-history
|
||||||
|
return true
|
||||||
|
fi
|
||||||
|
|
||||||
|
false
|
||||||
|
}
|
||||||
|
|
||||||
|
function _history-substring-search-up-history() {
|
||||||
|
#
|
||||||
|
# Behave like up in ZSH, except clear the $BUFFER
|
||||||
|
# when beginning of history is reached like in Fish.
|
||||||
|
#
|
||||||
|
if [[ -z $_history_substring_search_query ]]; then
|
||||||
|
|
||||||
|
# we have reached the absolute top of history
|
||||||
|
if [[ $HISTNO -eq 1 ]]; then
|
||||||
|
BUFFER=
|
||||||
|
|
||||||
|
# going up from somewhere below the top of history
|
||||||
|
else
|
||||||
|
zle up-history
|
||||||
|
fi
|
||||||
|
|
||||||
|
return true
|
||||||
|
fi
|
||||||
|
|
||||||
|
false
|
||||||
|
}
|
||||||
|
|
||||||
|
function _history-substring-search-down-history() {
|
||||||
|
#
|
||||||
|
# Behave like down-history in ZSH, except clear the
|
||||||
|
# $BUFFER when end of history is reached like in Fish.
|
||||||
|
#
|
||||||
|
if [[ -z $_history_substring_search_query ]]; then
|
||||||
|
|
||||||
|
# going down from the absolute top of history
|
||||||
|
if [[ $HISTNO -eq 1 && -z $BUFFER ]]; then
|
||||||
|
BUFFER=${history[1]}
|
||||||
|
_history_substring_search_move_cursor_eol=true
|
||||||
|
|
||||||
|
# going down from somewhere above the bottom of history
|
||||||
|
else
|
||||||
|
zle down-history
|
||||||
|
fi
|
||||||
|
|
||||||
|
return true
|
||||||
|
fi
|
||||||
|
|
||||||
|
false
|
||||||
|
}
|
||||||
|
|
||||||
|
function _history-substring-search-up-search() {
|
||||||
|
_history_substring_search_move_cursor_eol=true
|
||||||
|
|
||||||
|
#
|
||||||
|
# Highlight matches during history-substring-up-search:
|
||||||
|
#
|
||||||
|
# The following constants have been initialized in
|
||||||
|
# _history-substring-search-up/down-search():
|
||||||
|
#
|
||||||
|
# $_history_substring_search_matches is the current list of matches
|
||||||
|
# $_history_substring_search_matches_count is the current number of matches
|
||||||
|
# $_history_substring_search_matches_count_plus is the current number of matches + 1
|
||||||
|
# $_history_substring_search_matches_count_sans is the current number of matches - 1
|
||||||
|
# $_history_substring_search_match_index is the index of the current match
|
||||||
|
#
|
||||||
|
# The range of values that $_history_substring_search_match_index can take
|
||||||
|
# is: [0, $_history_substring_search_matches_count_plus]. A value of 0
|
||||||
|
# indicates that we are beyond the end of
|
||||||
|
# $_history_substring_search_matches. A value of
|
||||||
|
# $_history_substring_search_matches_count_plus indicates that we are beyond
|
||||||
|
# the beginning of $_history_substring_search_matches.
|
||||||
|
#
|
||||||
|
# In _history-substring-search-up-search() the initial value of
|
||||||
|
# $_history_substring_search_match_index is
|
||||||
|
# $_history_substring_search_matches_count_plus. This value is set in
|
||||||
|
# _history-substring-search-begin(). _history-substring-search-up-search()
|
||||||
|
# will initially decrease it to $_history_substring_search_matches_count.
|
||||||
|
#
|
||||||
|
if [[ $_history_substring_search_match_index -ge 2 ]]; then
|
||||||
|
#
|
||||||
|
# Highlight the next match:
|
||||||
|
#
|
||||||
|
# 1. Decrease the value of $_history_substring_search_match_index.
|
||||||
|
#
|
||||||
|
# 2. Use $HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_FOUND
|
||||||
|
# to highlight the current buffer.
|
||||||
|
#
|
||||||
|
(( _history_substring_search_match_index-- ))
|
||||||
|
BUFFER=$history[$_history_substring_search_matches[$_history_substring_search_match_index]]
|
||||||
|
_history_substring_search_query_highlight=$HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_FOUND
|
||||||
|
|
||||||
|
elif [[ $_history_substring_search_match_index -eq 1 ]]; then
|
||||||
|
#
|
||||||
|
# We will move beyond the end of $_history_substring_search_matches:
|
||||||
|
#
|
||||||
|
# 1. Decrease the value of $_history_substring_search_match_index.
|
||||||
|
#
|
||||||
|
# 2. Save the current buffer in $_history_substring_search_old_buffer,
|
||||||
|
# so that it can be retrieved by
|
||||||
|
# _history-substring-search-down-search() later.
|
||||||
|
#
|
||||||
|
# 3. Make $BUFFER equal to $_history_substring_search_query.
|
||||||
|
#
|
||||||
|
# 4. Use $HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_NOT_FOUND
|
||||||
|
# to highlight the current buffer.
|
||||||
|
#
|
||||||
|
(( _history_substring_search_match_index-- ))
|
||||||
|
_history_substring_search_old_buffer=$BUFFER
|
||||||
|
BUFFER=$_history_substring_search_query
|
||||||
|
_history_substring_search_query_highlight=$HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_NOT_FOUND
|
||||||
|
|
||||||
|
elif [[ $_history_substring_search_match_index -eq $_history_substring_search_matches_count_plus ]]; then
|
||||||
|
#
|
||||||
|
# We were beyond the beginning of $_history_substring_search_matches but
|
||||||
|
# UP makes us move back to $_history_substring_search_matches:
|
||||||
|
#
|
||||||
|
# 1. Decrease the value of $_history_substring_search_match_index.
|
||||||
|
#
|
||||||
|
# 2. Restore $BUFFER from $_history_substring_search_old_buffer.
|
||||||
|
#
|
||||||
|
# 3. Use $HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_FOUND
|
||||||
|
# to highlight the current buffer.
|
||||||
|
#
|
||||||
|
(( _history_substring_search_match_index-- ))
|
||||||
|
BUFFER=$_history_substring_search_old_buffer
|
||||||
|
_history_substring_search_query_highlight=$HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_FOUND
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
function _history-substring-search-down-search() {
|
||||||
|
_history_substring_search_move_cursor_eol=true
|
||||||
|
|
||||||
|
#
|
||||||
|
# Highlight matches during history-substring-up-search:
|
||||||
|
#
|
||||||
|
# The following constants have been initialized in
|
||||||
|
# _history-substring-search-up/down-search():
|
||||||
|
#
|
||||||
|
# $_history_substring_search_matches is the current list of matches
|
||||||
|
# $_history_substring_search_matches_count is the current number of matches
|
||||||
|
# $_history_substring_search_matches_count_plus is the current number of matches + 1
|
||||||
|
# $_history_substring_search_matches_count_sans is the current number of matches - 1
|
||||||
|
# $_history_substring_search_match_index is the index of the current match
|
||||||
|
#
|
||||||
|
# The range of values that $_history_substring_search_match_index can take
|
||||||
|
# is: [0, $_history_substring_search_matches_count_plus]. A value of 0
|
||||||
|
# indicates that we are beyond the end of
|
||||||
|
# $_history_substring_search_matches. A value of
|
||||||
|
# $_history_substring_search_matches_count_plus indicates that we are beyond
|
||||||
|
# the beginning of $_history_substring_search_matches.
|
||||||
|
#
|
||||||
|
# In _history-substring-search-down-search() the initial value of
|
||||||
|
# $_history_substring_search_match_index is
|
||||||
|
# $_history_substring_search_matches_count. This value is set in
|
||||||
|
# _history-substring-search-begin().
|
||||||
|
# _history-substring-search-down-search() will initially increase it to
|
||||||
|
# $_history_substring_search_matches_count_plus.
|
||||||
|
#
|
||||||
|
if [[ $_history_substring_search_match_index -le $_history_substring_search_matches_count_sans ]]; then
|
||||||
|
#
|
||||||
|
# Highlight the next match:
|
||||||
|
#
|
||||||
|
# 1. Increase $_history_substring_search_match_index by 1.
|
||||||
|
#
|
||||||
|
# 2. Use $HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_FOUND
|
||||||
|
# to highlight the current buffer.
|
||||||
|
#
|
||||||
|
(( _history_substring_search_match_index++ ))
|
||||||
|
BUFFER=$history[$_history_substring_search_matches[$_history_substring_search_match_index]]
|
||||||
|
_history_substring_search_query_highlight=$HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_FOUND
|
||||||
|
|
||||||
|
elif [[ $_history_substring_search_match_index -eq $_history_substring_search_matches_count ]]; then
|
||||||
|
#
|
||||||
|
# We will move beyond the beginning of $_history_substring_search_matches:
|
||||||
|
#
|
||||||
|
# 1. Increase $_history_substring_search_match_index by 1.
|
||||||
|
#
|
||||||
|
# 2. Save the current buffer in $_history_substring_search_old_buffer, so
|
||||||
|
# that it can be retrieved by _history-substring-search-up-search()
|
||||||
|
# later.
|
||||||
|
#
|
||||||
|
# 3. Make $BUFFER equal to $_history_substring_search_query.
|
||||||
|
#
|
||||||
|
# 4. Use $HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_NOT_FOUND
|
||||||
|
# to highlight the current buffer.
|
||||||
|
#
|
||||||
|
(( _history_substring_search_match_index++ ))
|
||||||
|
_history_substring_search_old_buffer=$BUFFER
|
||||||
|
BUFFER=$_history_substring_search_query
|
||||||
|
_history_substring_search_query_highlight=$HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_NOT_FOUND
|
||||||
|
|
||||||
|
elif [[ $_history_substring_search_match_index -eq 0 ]]; then
|
||||||
|
#
|
||||||
|
# We were beyond the end of $_history_substring_search_matches but DOWN
|
||||||
|
# makes us move back to the $_history_substring_search_matches:
|
||||||
|
#
|
||||||
|
# 1. Increase $_history_substring_search_match_index by 1.
|
||||||
|
#
|
||||||
|
# 2. Restore $BUFFER from $_history_substring_search_old_buffer.
|
||||||
|
#
|
||||||
|
# 3. Use $HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_FOUND
|
||||||
|
# to highlight the current buffer.
|
||||||
|
#
|
||||||
|
(( _history_substring_search_match_index++ ))
|
||||||
|
BUFFER=$_history_substring_search_old_buffer
|
||||||
|
_history_substring_search_query_highlight=$HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_FOUND
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# -*- mode: zsh; sh-indentation: 2; indent-tabs-mode: nil; sh-basic-offset: 2; -*-
|
||||||
|
# vim: ft=zsh sw=2 ts=2 et
|
9
plugins/kate/kate.plugin.zsh
Normal file
9
plugins/kate/kate.plugin.zsh
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
|
||||||
|
# Kate
|
||||||
|
# Start kate always silent
|
||||||
|
alias kate='kate >/dev/null 2>&1'
|
||||||
|
|
||||||
|
function kt () {
|
||||||
|
cd $1
|
||||||
|
kate $1
|
||||||
|
}
|
174
plugins/knife/_knife
Normal file
174
plugins/knife/_knife
Normal file
|
@ -0,0 +1,174 @@
|
||||||
|
#compdef knife
|
||||||
|
|
||||||
|
# These flags should be available everywhere according to man knife
|
||||||
|
knife_general_flags=( --help --server-url --key --config --editor --format --log_level --logfile --no-editor --user --print-after --version --yes )
|
||||||
|
|
||||||
|
# knife has a very special syntax, some example calls are:
|
||||||
|
# knife status
|
||||||
|
# knife cookbook list
|
||||||
|
# knife role show ROLENAME
|
||||||
|
# knife data bag show DATABAGNAME
|
||||||
|
# knife role show ROLENAME --attribute ATTRIBUTENAME
|
||||||
|
# knife cookbook show COOKBOOKNAME COOKBOOKVERSION recipes
|
||||||
|
|
||||||
|
# The -Q switch in compadd allow for completions of things like "data bag" without having to go through two rounds of completion and avoids zsh inserting a \ for escaping spaces
|
||||||
|
_knife() {
|
||||||
|
local curcontext="$curcontext" state line
|
||||||
|
typeset -A opt_args
|
||||||
|
cloudproviders=(bluebox ec2 rackspace slicehost terremark)
|
||||||
|
_arguments \
|
||||||
|
'1: :->knifecmd'\
|
||||||
|
'2: :->knifesubcmd'\
|
||||||
|
'3: :->knifesubcmd2' \
|
||||||
|
'4: :->knifesubcmd3' \
|
||||||
|
'5: :->knifesubcmd4' \
|
||||||
|
'6: :->knifesubcmd5'
|
||||||
|
|
||||||
|
case $state in
|
||||||
|
knifecmd)
|
||||||
|
compadd -Q "$@" bootstrap client configure cookbook "cookbook site" "data bag" exec index node recipe role search ssh status windows $cloudproviders
|
||||||
|
;;
|
||||||
|
knifesubcmd)
|
||||||
|
case $words[2] in
|
||||||
|
(bluebox|ec2|rackspace|slicehost|terremark)
|
||||||
|
compadd "$@" server images
|
||||||
|
;;
|
||||||
|
client)
|
||||||
|
compadd -Q "$@" "bulk delete" list create show delete edit reregister
|
||||||
|
;;
|
||||||
|
configure)
|
||||||
|
compadd "$@" client
|
||||||
|
;;
|
||||||
|
cookbook)
|
||||||
|
compadd -Q "$@" test list create download delete "metadata from" show "bulk delete" metadata upload
|
||||||
|
;;
|
||||||
|
node)
|
||||||
|
compadd -Q "$@" "from file" create show edit delete list run_list "bulk delete"
|
||||||
|
;;
|
||||||
|
recipe)
|
||||||
|
compadd "$@" list
|
||||||
|
;;
|
||||||
|
role)
|
||||||
|
compadd -Q "$@" "bulk delete" create delete edit "from file" list show
|
||||||
|
;;
|
||||||
|
windows)
|
||||||
|
compadd "$@" bootstrap
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
_arguments '2:Subsubcommands:($(_knife_options1))'
|
||||||
|
esac
|
||||||
|
;;
|
||||||
|
knifesubcmd2)
|
||||||
|
case $words[3] in
|
||||||
|
server)
|
||||||
|
compadd "$@" list create delete
|
||||||
|
;;
|
||||||
|
images)
|
||||||
|
compadd "$@" list
|
||||||
|
;;
|
||||||
|
site)
|
||||||
|
compadd "$@" vendor show share search download list unshare
|
||||||
|
;;
|
||||||
|
(show|delete|edit)
|
||||||
|
_arguments '3:Subsubcommands:($(_chef_$words[2]s_remote))'
|
||||||
|
;;
|
||||||
|
(upload|test)
|
||||||
|
_arguments '3:Subsubcommands:($(_chef_$words[2]s_local) --all)'
|
||||||
|
;;
|
||||||
|
list)
|
||||||
|
compadd -a "$@" knife_general_flags
|
||||||
|
;;
|
||||||
|
bag)
|
||||||
|
compadd -Q "$@" show edit list "from file" create delete
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
_arguments '3:Subsubcommands:($(_knife_options2))'
|
||||||
|
esac
|
||||||
|
;;
|
||||||
|
knifesubcmd3)
|
||||||
|
case $words[3] in
|
||||||
|
show)
|
||||||
|
case $words[2] in
|
||||||
|
cookbook)
|
||||||
|
versioncomp=1
|
||||||
|
_arguments '4:Cookbookversions:($(_cookbook_versions) latest)'
|
||||||
|
;;
|
||||||
|
(node|client|role)
|
||||||
|
compadd "$@" --attribute
|
||||||
|
esac
|
||||||
|
esac
|
||||||
|
case $words[4] in
|
||||||
|
(show|edit)
|
||||||
|
_arguments '4:Subsubsubcommands:($(_chef_$words[2]_$words[3]s_remote))'
|
||||||
|
;;
|
||||||
|
file)
|
||||||
|
_arguments '*:file or directory:_files -g "*.(rb|json)"'
|
||||||
|
;;
|
||||||
|
list)
|
||||||
|
compadd -a "$@" knife_general_flags
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
_arguments '*:Subsubcommands:($(_knife_options3))'
|
||||||
|
esac
|
||||||
|
;;
|
||||||
|
knifesubcmd4)
|
||||||
|
if (( versioncomp > 0 )); then
|
||||||
|
compadd "$@" attributes definitions files libraries providers recipes resources templates
|
||||||
|
else
|
||||||
|
_arguments '*:Subsubcommands:($(_knife_options2))'
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
knifesubcmd5)
|
||||||
|
_arguments '*:Subsubcommands:($(_knife_options3))'
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
# Helper functions to provide the argument completion for several depths of commands
|
||||||
|
_knife_options1() {
|
||||||
|
( for line in $( knife $words[2] --help | grep -v "^knife" ); do echo $line | grep "\-\-"; done )
|
||||||
|
}
|
||||||
|
|
||||||
|
_knife_options2() {
|
||||||
|
( for line in $( knife $words[2] $words[3] --help | grep -v "^knife" ); do echo $line | grep "\-\-"; done )
|
||||||
|
}
|
||||||
|
|
||||||
|
_knife_options3() {
|
||||||
|
( for line in $( knife $words[2] $words[3] $words[4] --help | grep -v "^knife" ); do echo $line | grep "\-\-"; done )
|
||||||
|
}
|
||||||
|
|
||||||
|
# The chef_x_remote functions use knife to get a list of objects of type x on the server
|
||||||
|
_chef_roles_remote() {
|
||||||
|
(knife role list | grep \" | awk '{print $1}' | awk -F"," '{print $1}' | awk -F"\"" '{print $2}')
|
||||||
|
}
|
||||||
|
|
||||||
|
_chef_clients_remote() {
|
||||||
|
(knife client list | grep \" | awk '{print $1}' | awk -F"," '{print $1}' | awk -F"\"" '{print $2}')
|
||||||
|
}
|
||||||
|
|
||||||
|
_chef_nodes_remote() {
|
||||||
|
(knife node list | grep \" | awk '{print $1}' | awk -F"," '{print $1}' | awk -F"\"" '{print $2}')
|
||||||
|
}
|
||||||
|
|
||||||
|
_chef_cookbooks_remote() {
|
||||||
|
(knife cookbook list | grep \" | awk '{print $1}' | awk -F"," '{print $1}' | awk -F"\"" '{print $2}')
|
||||||
|
}
|
||||||
|
|
||||||
|
_chef_sitecookbooks_remote() {
|
||||||
|
(knife cookbook site list | grep \" | awk '{print $1}' | awk -F"," '{print $1}' | awk -F"\"" '{print $2}')
|
||||||
|
}
|
||||||
|
|
||||||
|
_chef_data_bags_remote() {
|
||||||
|
(knife data bag list | grep \" | awk '{print $1}' | awk -F"," '{print $1}' | awk -F"\"" '{print $2}')
|
||||||
|
}
|
||||||
|
|
||||||
|
# The chef_x_local functions use the knife config to find the paths of relevant objects x to be uploaded to the server
|
||||||
|
_chef_cookbooks_local() {
|
||||||
|
(for i in $( grep cookbook_path $HOME/.chef/knife.rb | awk 'BEGIN {FS = "[" }; {print $2}' | sed 's/\,//g' | sed "s/'//g" | sed 's/\(.*\)]/\1/' ); do ls $i; done)
|
||||||
|
}
|
||||||
|
|
||||||
|
# This function extracts the available cookbook versions on the chef server
|
||||||
|
_cookbook_versions() {
|
||||||
|
(knife cookbook show $words[4] | grep -v $words[4] | grep -v -E '\]|\[|\{|\}' | sed 's/ //g' | sed 's/"//g')
|
||||||
|
}
|
||||||
|
|
||||||
|
_knife "$@"
|
|
@ -8,19 +8,30 @@ alias rtfm='man'
|
||||||
alias visible='echo'
|
alias visible='echo'
|
||||||
alias invisible='cat'
|
alias invisible='cat'
|
||||||
alias moar='more'
|
alias moar='more'
|
||||||
|
alias tldr='less'
|
||||||
|
alias alwayz='tail -f'
|
||||||
|
|
||||||
alias icanhas='mkdir'
|
alias icanhas='mkdir'
|
||||||
|
alias gimmeh='touch'
|
||||||
alias donotwant='rm'
|
alias donotwant='rm'
|
||||||
alias dowant='cp'
|
alias dowant='cp'
|
||||||
alias gtfo='mv'
|
alias gtfo='mv'
|
||||||
|
alias nowai='chmod'
|
||||||
|
|
||||||
alias hai='cd'
|
alias hai='cd'
|
||||||
|
alias iz='ls'
|
||||||
alias plz='pwd'
|
alias plz='pwd'
|
||||||
|
alias ihasbucket='df -h'
|
||||||
|
|
||||||
alias inur='locate'
|
alias inur='locate'
|
||||||
|
alias iminurbase='finger'
|
||||||
|
|
||||||
|
alias btw='nice'
|
||||||
|
alias obtw='nohup'
|
||||||
|
|
||||||
alias nomz='ps -aux'
|
alias nomz='ps -aux'
|
||||||
alias nomnom='killall'
|
alias nomnom='killall'
|
||||||
|
|
||||||
|
alias byes='exit'
|
||||||
alias cya='reboot'
|
alias cya='reboot'
|
||||||
alias kthxbai='halt'
|
alias kthxbai='halt'
|
||||||
|
|
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"
|
||||||
|
}
|
5
plugins/osx/_man-preview
Normal file
5
plugins/osx/_man-preview
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
#compdef man-preview
|
||||||
|
#autoload
|
||||||
|
|
||||||
|
_man
|
||||||
|
|
|
@ -1,57 +1,99 @@
|
||||||
function savepath() {
|
# ------------------------------------------------------------------------------
|
||||||
pwd > ~/.current_path~
|
# FILE: osx.plugin.zsh
|
||||||
}
|
# DESCRIPTION: oh-my-zsh plugin file.
|
||||||
|
# AUTHOR: Sorin Ionescu (sorin.ionescu@gmail.com)
|
||||||
|
# VERSION: 1.0.1
|
||||||
|
# ------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
|
||||||
function tab() {
|
function tab() {
|
||||||
savepath
|
local command="cd \\\"$PWD\\\""
|
||||||
osascript >/dev/null <<EOF
|
(( $# > 0 )) && command="${command}; $*"
|
||||||
on do_submenu(app_name, menu_name, menu_item, submenu_item)
|
|
||||||
-- bring the target application to the front
|
|
||||||
tell application app_name
|
|
||||||
activate
|
|
||||||
end tell
|
|
||||||
tell application "System Events"
|
|
||||||
tell process app_name
|
|
||||||
tell menu bar 1
|
|
||||||
tell menu bar item menu_name
|
|
||||||
tell menu menu_name
|
|
||||||
tell menu item menu_item
|
|
||||||
tell menu menu_item
|
|
||||||
click menu item submenu_item
|
|
||||||
end tell
|
|
||||||
end tell
|
|
||||||
end tell
|
|
||||||
end tell
|
|
||||||
end tell
|
|
||||||
end tell
|
|
||||||
end tell
|
|
||||||
end do_submenu
|
|
||||||
|
|
||||||
do_submenu("Terminal", "Shell", "New Tab", 1)
|
the_app=$(
|
||||||
|
osascript 2>/dev/null <<EOF
|
||||||
|
tell application "System Events"
|
||||||
|
name of first item of (every process whose frontmost is true)
|
||||||
|
end tell
|
||||||
|
EOF
|
||||||
|
)
|
||||||
|
|
||||||
|
[[ "$the_app" == 'Terminal' ]] && {
|
||||||
|
osascript 2>/dev/null <<EOF
|
||||||
|
tell application "System Events"
|
||||||
|
tell process "Terminal" to keystroke "t" using command down
|
||||||
|
tell application "Terminal" to do script "${command}" in front window
|
||||||
|
end tell
|
||||||
|
EOF
|
||||||
|
}
|
||||||
|
|
||||||
|
[[ "$the_app" == 'iTerm' ]] && {
|
||||||
|
osascript 2>/dev/null <<EOF
|
||||||
|
tell application "iTerm"
|
||||||
|
set current_terminal to current terminal
|
||||||
|
tell current_terminal
|
||||||
|
launch session "Default Session"
|
||||||
|
set current_session to current session
|
||||||
|
tell current_session
|
||||||
|
write text "${command}"
|
||||||
|
end tell
|
||||||
|
end tell
|
||||||
|
end tell
|
||||||
|
EOF
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function pfd() {
|
||||||
|
osascript 2>/dev/null <<EOF
|
||||||
|
tell application "Finder"
|
||||||
|
return POSIX path of (target of window 1 as alias)
|
||||||
|
end tell
|
||||||
EOF
|
EOF
|
||||||
}
|
}
|
||||||
|
|
||||||
function itab() {
|
function pfs() {
|
||||||
savepath
|
osascript 2>/dev/null <<EOF
|
||||||
osascript >/dev/null <<EOF
|
set output to ""
|
||||||
on do_submenu(app_name, menu_name, menu_item)
|
tell application "Finder" to set the_selection to selection
|
||||||
-- bring the target application to the front
|
set item_count to count the_selection
|
||||||
tell application app_name
|
repeat with item_index from 1 to count the_selection
|
||||||
activate
|
if item_index is less than item_count then set the_delimiter to "\n"
|
||||||
end tell
|
if item_index is item_count then set the_delimiter to ""
|
||||||
tell application "System Events"
|
set output to output & ((item item_index of the_selection as alias)'s POSIX path) & the_delimiter
|
||||||
tell process app_name
|
end repeat
|
||||||
tell menu bar 1
|
|
||||||
tell menu bar item menu_name
|
|
||||||
tell menu menu_name
|
|
||||||
click menu item menu_item
|
|
||||||
end tell
|
|
||||||
end tell
|
|
||||||
end tell
|
|
||||||
end tell
|
|
||||||
end tell
|
|
||||||
end do_submenu
|
|
||||||
|
|
||||||
do_submenu("iTerm", "Shell", "New Tab")
|
|
||||||
EOF
|
EOF
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function cdf() {
|
||||||
|
cd "$(pfd)"
|
||||||
|
}
|
||||||
|
|
||||||
|
function pushdf() {
|
||||||
|
pushd "$(pfd)"
|
||||||
|
}
|
||||||
|
|
||||||
|
function quick-look() {
|
||||||
|
(( $# > 0 )) && qlmanage -p $* &>/dev/null &
|
||||||
|
}
|
||||||
|
|
||||||
|
function man-preview() {
|
||||||
|
man -t "$@" | open -f -a Preview
|
||||||
|
}
|
||||||
|
|
||||||
|
function trash() {
|
||||||
|
local trash_dir="${HOME}/.Trash"
|
||||||
|
local temp_ifs=$IFS
|
||||||
|
IFS=$'\n'
|
||||||
|
for item in "$@"; do
|
||||||
|
if [[ -e "$item" ]]; then
|
||||||
|
item_name="$(basename $item)"
|
||||||
|
if [[ -e "${trash_dir}/${item_name}" ]]; then
|
||||||
|
mv -f "$item" "${trash_dir}/${item_name} $(date "+%H-%M-%S")"
|
||||||
|
else
|
||||||
|
mv -f "$item" "${trash_dir}/"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
IFS=$temp_ifs
|
||||||
|
}
|
||||||
|
|
||||||
|
|
|
@ -10,7 +10,6 @@ _phing_does_target_list_need_generating () {
|
||||||
_phing () {
|
_phing () {
|
||||||
if [ -f build.xml ]; then
|
if [ -f build.xml ]; then
|
||||||
if _phing_does_target_list_need_generating; then
|
if _phing_does_target_list_need_generating; then
|
||||||
echo "\nGenerating .phing_targets..." > /dev/stderr
|
|
||||||
phing -l |grep -v ":" |grep -v "^$"|grep -v "\-" > .phing_targets
|
phing -l |grep -v ":" |grep -v "^$"|grep -v "\-" > .phing_targets
|
||||||
fi
|
fi
|
||||||
compadd `cat .phing_targets`
|
compadd `cat .phing_targets`
|
||||||
|
|
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
|
4
plugins/powder/_powder
Normal file
4
plugins/powder/_powder
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
#compdef powder
|
||||||
|
#autoload
|
||||||
|
|
||||||
|
compadd `powder help | grep powder | cut -d " " -f 4`
|
|
@ -1,13 +1,5 @@
|
||||||
# Rails 3 aliases, backwards-compatible with Rails 2.
|
# Rails 3 aliases, backwards-compatible with Rails 2.
|
||||||
|
|
||||||
function _bundle_command {
|
|
||||||
if command -v bundle && [ -e "Gemfile" ]; then
|
|
||||||
bundle exec $@
|
|
||||||
else
|
|
||||||
$@
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
function _rails_command () {
|
function _rails_command () {
|
||||||
if [ -e "script/server" ]; then
|
if [ -e "script/server" ]; then
|
||||||
ruby script/$@
|
ruby script/$@
|
||||||
|
@ -25,6 +17,3 @@ alias rp='_rails_command plugin'
|
||||||
alias rs='_rails_command server'
|
alias rs='_rails_command server'
|
||||||
alias rsd='_rails_command server --debugger'
|
alias rsd='_rails_command server --debugger'
|
||||||
alias devlog='tail -f log/development.log'
|
alias devlog='tail -f log/development.log'
|
||||||
|
|
||||||
alias rspec='_bundle_command rspec'
|
|
||||||
alias cuke='_bundle_command cucumber'
|
|
||||||
|
|
|
@ -51,7 +51,7 @@ _1st_arguments=(
|
||||||
'keys:find all keys matching the given pattern'
|
'keys:find all keys matching the given pattern'
|
||||||
'lastsave:get the UNIX timestamp of the last successful save to disk'
|
'lastsave:get the UNIX timestamp of the last successful save to disk'
|
||||||
'lindex:get an element from a list by its index'
|
'lindex:get an element from a list by its index'
|
||||||
'linset:insert an element before or after another element in a list'
|
'linsert:insert an element before or after another element in a list'
|
||||||
'llen:get the length of a list'
|
'llen:get the length of a list'
|
||||||
'lpop:remove and get the first element in a list'
|
'lpop:remove and get the first element in a list'
|
||||||
'lpush:prepend a value to a list'
|
'lpush:prepend a value to a list'
|
||||||
|
|
|
@ -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
|
||||||
|
|
147
plugins/rvm/_rvm
Normal file
147
plugins/rvm/_rvm
Normal file
|
@ -0,0 +1,147 @@
|
||||||
|
#compdef rvm
|
||||||
|
|
||||||
|
local curcontext="$curcontext" state line cmds ret=1
|
||||||
|
|
||||||
|
_arguments -C \
|
||||||
|
'(- 1 *)'{-v,--version}'[display version information]' \
|
||||||
|
'(-l|--level)'{-l,--level}'+[patch level to use with rvm use / install]:number' \
|
||||||
|
'(--prefix)--prefix[path for all rvm files (~/.rvm/), with trailing slash!]:path:_files' \
|
||||||
|
'(--bin)--bin[path for binaries to be placed (~/.rvm/bin/)]:path:_files' \
|
||||||
|
'(--source)--source[src directory to use (~/.rvm/src/)]:path:_files' \
|
||||||
|
'(--archives)--archives[directory for downladed files (~/.rvm/archives/)]:path:_files' \
|
||||||
|
'-S[Specify a script file to attempt to load and run (rubydo)]:file:_files' \
|
||||||
|
'-e[Execute code from the command line]:code' \
|
||||||
|
'(-G)-G[root gem path to use]:path:_files' \
|
||||||
|
'(--gems)--gems[Used to set the gems_flag, use with remove to remove gems]' \
|
||||||
|
'(--archive)--archive[Used to set the archive_flag, use with remove to remove archive]' \
|
||||||
|
'(--patch)--patch[With MRI Rubies you may specify one or more full paths to patches]' \
|
||||||
|
'(-C|--configure)'{-C,--configure}'=[custom configure options]' \
|
||||||
|
'(--nice)--nice[process niceness (for slow computers, default 0)]:number' \
|
||||||
|
'(--ree)--ree-options[Options passed directly to ree ./installer on the command line]:options' \
|
||||||
|
'(--head)--head[with update, updates rvm to git head version]' \
|
||||||
|
'(--rubygems)--rubygems[with update, updates rubygems for selected ruby]' \
|
||||||
|
'(--default)--default[with ruby select, sets a default ruby for new shells]' \
|
||||||
|
'(--debug)--debug[Toggle debug mode on for very verbose output]' \
|
||||||
|
'(--trace)--trace[Toggle trace mode on to see EVERYTHING rvm is doing]' \
|
||||||
|
'(--force)--force[Force install, removes old install & source before install]' \
|
||||||
|
'(--summary)--summary[Used with rubydo to print out a summary of the commands run]' \
|
||||||
|
'(--latest)--latest[with gemset --dump skips version strings for latest gem]' \
|
||||||
|
'(--gems)--gems[with uninstall/remove removes gems with the interpreter]' \
|
||||||
|
'(--docs)--docs[with install, attempt to generate ri after installation]' \
|
||||||
|
'(--reconfigure)--reconfigure[Force ./configure on install even if Makefile already exists]' \
|
||||||
|
'1: :->cmds' \
|
||||||
|
'*: :->args' && ret=0
|
||||||
|
|
||||||
|
case $state in
|
||||||
|
cmds)
|
||||||
|
cmds=(
|
||||||
|
"version:show the rvm version installed in rvm_path"
|
||||||
|
"use:setup current shell to use a specific ruby version"
|
||||||
|
"reload:reload rvm source itself (useful after changing rvm source)"
|
||||||
|
"implode:(seppuku) removes the rvm installation completely. This means everything in $rvm_path (~/.rvm)."
|
||||||
|
"update:upgrades rvm to the latest version."
|
||||||
|
"reset:remove current and stored default & system settings."
|
||||||
|
"info :show the *current* environment information for current ruby"
|
||||||
|
"current:print the *current* ruby version and the name of any gemset being used."
|
||||||
|
"debug:show info plus additional information for common issues"
|
||||||
|
"install:install one or many ruby versions"
|
||||||
|
"uninstall:uninstall one or many ruby versions, leaves their sources"
|
||||||
|
"remove:uninstall one or many ruby versions and remove their sources"
|
||||||
|
"migrate:Lets you migrate all gemsets from one ruby to another."
|
||||||
|
"upgrade:Lets you upgrade from one version of a ruby to another, including migrating your gemsets semi-automatically."
|
||||||
|
"wrapper:generates a set of wrapper executables for a given ruby with the specified ruby and gemset combination. Used under the hood for passenger support and the like."
|
||||||
|
"cleanup:Lets you remove stale source folders / archives and other miscellaneous data associated with rvm."
|
||||||
|
"repair:Lets you repair parts of your environment e.g. wrappers, env files and and similar files (e.g. general maintenance)."
|
||||||
|
"snapshot:Lets your backup / restore an rvm installation in a lightweight manner."
|
||||||
|
"disk-usage:Tells you how much disk space rvm install is using."
|
||||||
|
"tools:Provides general information about the ruby environment, primarily useful when scripting rvm."
|
||||||
|
"docs:Tools to make installing ri and rdoc documentation easier."
|
||||||
|
"rvmrc:Tools related to managing rvmrc trust and loading."
|
||||||
|
"exec:runs an arbitrary command as a set operation."
|
||||||
|
"ruby:runs a named ruby file against specified and/or all rubies"
|
||||||
|
"gem:runs a gem command using selected ruby's 'gem'"
|
||||||
|
"rake:runs a rake task against specified and/or all rubies"
|
||||||
|
"tests:runs 'rake test' across selected ruby versions"
|
||||||
|
"specs:runs 'rake spec' across selected ruby versions"
|
||||||
|
"monitor:Monitor cwd for testing, run rake {spec,test} on changes."
|
||||||
|
"gemset:gemsets: http://rvm.beginrescueend.com/gemsets/"
|
||||||
|
"rubygems:Switches the installed version of rubygems for the current ruby."
|
||||||
|
"gemdir:display the path to the current gem directory (GEM_HOME)."
|
||||||
|
"srcdir:display the path to rvm source directory (may be yanked)"
|
||||||
|
"fetch:Performs an archive / src fetch only of the selected ruby."
|
||||||
|
"list:show currently installed rubies, interactive output."
|
||||||
|
"package:Install a dependency package {readline,iconv,zlib,openssl}"
|
||||||
|
"notes:Display notes, with operating system specifics."
|
||||||
|
"export:Temporarily set an environment variable in the current shell."
|
||||||
|
"unexport:Undo changes made to the environment by 'rvm export'."
|
||||||
|
)
|
||||||
|
_describe -t commands 'rvm command' cmds && ret=0
|
||||||
|
;;
|
||||||
|
args)
|
||||||
|
case $line[1] in
|
||||||
|
(use|uninstall|remove|list)
|
||||||
|
_values -S , 'rubies' $(rvm list strings | sed -e 's/ruby-\([^) ]*\)-\([^) ]*\)/ruby-\1-\2 \1-\2 \1/g') default system && ret=0
|
||||||
|
;;
|
||||||
|
(install|fetch)
|
||||||
|
_values -S , 'rubies' $(rvm list known_strings) && ret=0
|
||||||
|
;;
|
||||||
|
gemset)
|
||||||
|
if (( CURRENT == 3 )); then
|
||||||
|
_values 'gemset_commands' \
|
||||||
|
'import' \
|
||||||
|
'export' \
|
||||||
|
'create' \
|
||||||
|
'copy' \
|
||||||
|
'rename' \
|
||||||
|
'empty' \
|
||||||
|
'delete' \
|
||||||
|
'name' \
|
||||||
|
'dir' \
|
||||||
|
'list' \
|
||||||
|
'list_all' \
|
||||||
|
'gemdir' \
|
||||||
|
'install' \
|
||||||
|
'pristine' \
|
||||||
|
'clear' \
|
||||||
|
'use' \
|
||||||
|
'update' \
|
||||||
|
'unpack' \
|
||||||
|
'globalcache'
|
||||||
|
else
|
||||||
|
_values -S , 'gemsets' $(rvm gemset list | grep -v gemset 2>/dev/null)
|
||||||
|
fi
|
||||||
|
ret=0
|
||||||
|
;;
|
||||||
|
package)
|
||||||
|
if (( CURRENT == 3 )); then
|
||||||
|
_values 'package_commands' \
|
||||||
|
'install' \
|
||||||
|
'uninstall'
|
||||||
|
else
|
||||||
|
_values 'packages' \
|
||||||
|
'readline' \
|
||||||
|
'iconv' \
|
||||||
|
'curl' \
|
||||||
|
'openssl' \
|
||||||
|
'zlib' \
|
||||||
|
'autoconf' \
|
||||||
|
'ncurses' \
|
||||||
|
'pkgconfig' \
|
||||||
|
'gettext' \
|
||||||
|
'glib' \
|
||||||
|
'mono' \
|
||||||
|
'llvm' \
|
||||||
|
'libxml2' \
|
||||||
|
'libxslt' \
|
||||||
|
'libyaml'
|
||||||
|
fi
|
||||||
|
ret=0
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
(( ret )) && _message 'no more arguments'
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
return ret
|
44
plugins/rvm/rvm.plugin.zsh
Normal file
44
plugins/rvm/rvm.plugin.zsh
Normal file
|
@ -0,0 +1,44 @@
|
||||||
|
alias rubies='rvm list rubies'
|
||||||
|
alias gemsets='rvm gemset list'
|
||||||
|
|
||||||
|
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,23 +1,62 @@
|
||||||
|
#
|
||||||
|
# INSTRUCTIONS
|
||||||
|
#
|
||||||
|
# To enabled agent forwarding support add the following to
|
||||||
|
# your .zshrc file:
|
||||||
|
#
|
||||||
|
# zstyle :omz:plugins:ssh-agent agent-forwarding on
|
||||||
|
#
|
||||||
|
# To load multiple identies use the identities style, For
|
||||||
|
# example:
|
||||||
|
#
|
||||||
|
# zstyle :omz:plugins:ssh-agent id_rsa id_rsa2 id_github
|
||||||
|
#
|
||||||
|
#
|
||||||
|
# CREDITS
|
||||||
|
#
|
||||||
# Based on code from Joseph M. Reagle
|
# Based on code from Joseph M. Reagle
|
||||||
# http://www.cygwin.com/ml/cygwin/2001-06/msg00537.html
|
# http://www.cygwin.com/ml/cygwin/2001-06/msg00537.html
|
||||||
|
#
|
||||||
|
# Agent forwarding support based on ideas from
|
||||||
|
# Florent Thoumie and Jonas Pfenniger
|
||||||
|
#
|
||||||
|
|
||||||
local SSH_ENV=$HOME/.ssh/environment-$HOST
|
local _plugin__ssh_env=$HOME/.ssh/environment-$HOST
|
||||||
|
local _plugin__forwarding
|
||||||
|
|
||||||
function start_agent {
|
function _plugin__start_agent()
|
||||||
/usr/bin/env ssh-agent | sed 's/^echo/#echo/' > ${SSH_ENV}
|
{
|
||||||
chmod 600 ${SSH_ENV}
|
local -a identities
|
||||||
. ${SSH_ENV} > /dev/null
|
|
||||||
/usr/bin/ssh-add;
|
# start ssh-agent and setup environment
|
||||||
|
/usr/bin/env ssh-agent | sed 's/^echo/#echo/' > ${_plugin__ssh_env}
|
||||||
|
chmod 600 ${_plugin__ssh_env}
|
||||||
|
. ${_plugin__ssh_env} > /dev/null
|
||||||
|
|
||||||
|
# load identies
|
||||||
|
zstyle -a :omz:plugins:ssh-agent identities identities
|
||||||
|
echo starting...
|
||||||
|
/usr/bin/ssh-add $HOME/.ssh/${^identities}
|
||||||
}
|
}
|
||||||
|
|
||||||
# Source SSH settings, if applicable
|
# test if agent-forwarding is enabled
|
||||||
|
zstyle -b :omz:plugins:ssh-agent agent-forwarding _plugin__forwarding
|
||||||
|
if [[ ${_plugin__forwarding} == "yes" && -n "$SSH_AUTH_SOCK" ]]; then
|
||||||
|
# Add a nifty symlink for screen/tmux if agent forwarding
|
||||||
|
[[ -L $SSH_AUTH_SOCK ]] || ln -sf "$SSH_AUTH_SOCK" /tmp/ssh-agent-$USER-screen
|
||||||
|
|
||||||
if [ -f "${SSH_ENV}" ]; then
|
elif [ -f "${_plugin__ssh_env}" ]; then
|
||||||
. ${SSH_ENV} > /dev/null
|
# Source SSH settings, if applicable
|
||||||
|
. ${_plugin__ssh_env} > /dev/null
|
||||||
ps -ef | grep ${SSH_AGENT_PID} | grep ssh-agent$ > /dev/null || {
|
ps -ef | grep ${SSH_AGENT_PID} | grep ssh-agent$ > /dev/null || {
|
||||||
start_agent;
|
_plugin__start_agent;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
start_agent;
|
_plugin__start_agent;
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# tidy up after ourselves
|
||||||
|
unfunction _plugin__start_agent
|
||||||
|
unset _plugin__forwarding
|
||||||
|
unset _plugin__ssh_env
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
function svn_prompt_info {
|
function svn_prompt_info {
|
||||||
if [[ -d .svn ]]; then
|
if [ in_svn ]; then
|
||||||
echo "$ZSH_PROMPT_BASE_COLOR$ZSH_THEME_SVN_PROMPT_PREFIX\
|
echo "$ZSH_PROMPT_BASE_COLOR$ZSH_THEME_SVN_PROMPT_PREFIX\
|
||||||
$ZSH_THEME_REPO_NAME_COLOR$(svn_get_repo_name)$ZSH_PROMPT_BASE_COLOR$ZSH_THEME_SVN_PROMPT_SUFFIX$ZSH_PROMPT_BASE_COLOR$(svn_dirty)$ZSH_PROMPT_BASE_COLOR"
|
$ZSH_THEME_REPO_NAME_COLOR$(svn_get_repo_name)$ZSH_PROMPT_BASE_COLOR$ZSH_THEME_SVN_PROMPT_SUFFIX$ZSH_PROMPT_BASE_COLOR$(svn_dirty)$ZSH_PROMPT_BASE_COLOR"
|
||||||
fi
|
fi
|
||||||
|
@ -13,7 +13,7 @@ function in_svn() {
|
||||||
}
|
}
|
||||||
|
|
||||||
function svn_get_repo_name {
|
function svn_get_repo_name {
|
||||||
if [ is_svn ]; then
|
if [ in_svn ]; then
|
||||||
svn info | sed -n 's/Repository\ Root:\ .*\///p' | read SVN_ROOT
|
svn info | sed -n 's/Repository\ Root:\ .*\///p' | read SVN_ROOT
|
||||||
|
|
||||||
svn info | sed -n "s/URL:\ .*$SVN_ROOT\///p" | sed "s/\/.*$//"
|
svn info | sed -n "s/URL:\ .*$SVN_ROOT\///p" | sed "s/\/.*$//"
|
||||||
|
@ -21,14 +21,14 @@ function svn_get_repo_name {
|
||||||
}
|
}
|
||||||
|
|
||||||
function svn_get_rev_nr {
|
function svn_get_rev_nr {
|
||||||
if [ is_svn ]; then
|
if [ in_svn ]; then
|
||||||
svn info 2> /dev/null | sed -n s/Revision:\ //p
|
svn info 2> /dev/null | sed -n s/Revision:\ //p
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
function svn_dirty_choose {
|
function svn_dirty_choose {
|
||||||
if [ is_svn ]; then
|
if [ in_svn ]; then
|
||||||
s=$(svn status 2>/dev/null)
|
s=$(svn status|grep -E '^\s*[ACDIM!?L]' 2>/dev/null)
|
||||||
if [ $s ]; then
|
if [ $s ]; then
|
||||||
echo $1
|
echo $1
|
||||||
else
|
else
|
||||||
|
|
280
plugins/taskwarrior/_task
Normal file
280
plugins/taskwarrior/_task
Normal file
|
@ -0,0 +1,280 @@
|
||||||
|
#compdef task
|
||||||
|
#
|
||||||
|
# zsh completion for taskwarrior
|
||||||
|
#
|
||||||
|
# Copyright 2010 - 2011 Johannes Schlatow
|
||||||
|
# Copyright 2009 P.C. Shyamshankar
|
||||||
|
# All rights reserved.
|
||||||
|
#
|
||||||
|
# This script is part of the taskwarrior project.
|
||||||
|
#
|
||||||
|
# This program is free software; you can redistribute it and/or modify it under
|
||||||
|
# the terms of the GNU General Public License as published by the Free Software
|
||||||
|
# Foundation; either version 2 of the License, or (at your option) any later
|
||||||
|
# version.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
||||||
|
# FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
||||||
|
# details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License along with
|
||||||
|
# this program; if not, write to the
|
||||||
|
#
|
||||||
|
# Free Software Foundation, Inc.,
|
||||||
|
# 51 Franklin Street, Fifth Floor,
|
||||||
|
# Boston, MA
|
||||||
|
# 02110-1301
|
||||||
|
# USA
|
||||||
|
#
|
||||||
|
typeset -g _task_cmds _task_projects _task_tags _task_config _task_modifiers
|
||||||
|
_task_projects=($(task _projects))
|
||||||
|
_task_tags=($(task _tags))
|
||||||
|
_task_ids=($(task _ids))
|
||||||
|
_task_config=($(task _config))
|
||||||
|
_task_modifiers=(
|
||||||
|
'before' \
|
||||||
|
'after' \
|
||||||
|
'none' \
|
||||||
|
'any' \
|
||||||
|
'is' \
|
||||||
|
'isnt' \
|
||||||
|
'has' \
|
||||||
|
'hasnt' \
|
||||||
|
'startswith' \
|
||||||
|
'endswith' \
|
||||||
|
'word' \
|
||||||
|
'noword'
|
||||||
|
)
|
||||||
|
_task_cmds=($(task _commands))
|
||||||
|
_task_zshcmds=( ${(f)"$(task _zshcommands)"} )
|
||||||
|
|
||||||
|
|
||||||
|
_task_idCmds=(
|
||||||
|
'append' \
|
||||||
|
'prepend' \
|
||||||
|
'annotate' \
|
||||||
|
'denotate' \
|
||||||
|
'edit' \
|
||||||
|
'duplicate' \
|
||||||
|
'info' \
|
||||||
|
'start' \
|
||||||
|
'stop' \
|
||||||
|
'done'
|
||||||
|
)
|
||||||
|
|
||||||
|
_task_idCmdsDesc=(
|
||||||
|
'append:Appends more description to an existing task.' \
|
||||||
|
'prepend:Prepends more description to an existing task.' \
|
||||||
|
'annotate:Adds an annotation to an existing task.' \
|
||||||
|
'denotate:Deletes an annotation of an existing task.' \
|
||||||
|
'edit:Launches an editor to let you modify a task directly.' \
|
||||||
|
'duplicate:Duplicates the specified task, and allows modifications.' \
|
||||||
|
'info:Shows all data, metadata for specified task.' \
|
||||||
|
'start:Marks specified task as started.' \
|
||||||
|
'stop:Removes the start time from a task.' \
|
||||||
|
'done:Marks the specified task as completed.'
|
||||||
|
)
|
||||||
|
|
||||||
|
_task() {
|
||||||
|
_arguments -s -S \
|
||||||
|
"*::task command:_task_commands"
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
local -a reply args word
|
||||||
|
word=$'[^\0]#\0'
|
||||||
|
|
||||||
|
# priorities
|
||||||
|
local -a task_priorities
|
||||||
|
_regex_words values 'task priorities' \
|
||||||
|
'H:High' \
|
||||||
|
'M:Middle' \
|
||||||
|
'L:Low'
|
||||||
|
task_priorities=("$reply[@]")
|
||||||
|
|
||||||
|
# projects
|
||||||
|
local -a task_projects
|
||||||
|
task_projects=(
|
||||||
|
/"$word"/
|
||||||
|
":values:task projects:compadd -a _task_projects"
|
||||||
|
)
|
||||||
|
|
||||||
|
local -a _task_dates
|
||||||
|
_regex_words values 'task dates' \
|
||||||
|
'tod*ay:Today' \
|
||||||
|
'yes*terday:Yesterday' \
|
||||||
|
'tom*orrow:Tomorrow' \
|
||||||
|
'sow:Start of week' \
|
||||||
|
'soww:Start of work week' \
|
||||||
|
'socw:Start of calendar week' \
|
||||||
|
'som:Start of month' \
|
||||||
|
'soy:Start of year' \
|
||||||
|
'eow:End of week' \
|
||||||
|
'eoww:End of work week' \
|
||||||
|
'eocw:End of calendar week' \
|
||||||
|
'eom:End of month' \
|
||||||
|
'eoy:End of year' \
|
||||||
|
'mon:Monday' \
|
||||||
|
'tue:Tuesday'\
|
||||||
|
'wed:Wednesday' \
|
||||||
|
'thu:Thursday' \
|
||||||
|
'fri:Friday' \
|
||||||
|
'sat:Saturday' \
|
||||||
|
'sun:Sunday'
|
||||||
|
_task_dates=("$reply[@]")
|
||||||
|
|
||||||
|
local -a _task_reldates
|
||||||
|
_regex_words values 'task reldates' \
|
||||||
|
'hrs:n hours' \
|
||||||
|
'day:n days' \
|
||||||
|
'1st:first' \
|
||||||
|
'2nd:second' \
|
||||||
|
'3rd:third' \
|
||||||
|
'th:4th, 5th, etc.' \
|
||||||
|
'wks:weeks'
|
||||||
|
_task_reldates=("$reply[@]")
|
||||||
|
|
||||||
|
task_dates=(
|
||||||
|
\( "$_task_dates[@]" \|
|
||||||
|
\( /$'[0-9][0-9]#'/- \( "$_task_reldates[@]" \) \)
|
||||||
|
\)
|
||||||
|
)
|
||||||
|
|
||||||
|
_regex_words values 'task frequencies' \
|
||||||
|
'daily:Every day' \
|
||||||
|
'day:Every day' \
|
||||||
|
'weekdays:Every day skipping weekend days' \
|
||||||
|
'weekly:Every week' \
|
||||||
|
'biweekly:Every two weeks' \
|
||||||
|
'fortnight:Every two weeks' \
|
||||||
|
'quarterly:Every three months' \
|
||||||
|
'semiannual:Every six months' \
|
||||||
|
'annual:Every year' \
|
||||||
|
'yearly:Every year' \
|
||||||
|
'biannual:Every two years' \
|
||||||
|
'biyearly:Every two years'
|
||||||
|
_task_freqs=("$reply[@]")
|
||||||
|
|
||||||
|
local -a _task_frequencies
|
||||||
|
_regex_words values 'task frequencies' \
|
||||||
|
'd:days' \
|
||||||
|
'w:weeks' \
|
||||||
|
'q:quarters' \
|
||||||
|
'y:years'
|
||||||
|
_task_frequencies=("$reply[@]")
|
||||||
|
|
||||||
|
task_freqs=(
|
||||||
|
\( "$_task_freqs[@]" \|
|
||||||
|
\( /$'[0-9][0-9]#'/- \( "$_task_frequencies[@]" \) \)
|
||||||
|
\)
|
||||||
|
)
|
||||||
|
|
||||||
|
# attributes
|
||||||
|
local -a task_attributes
|
||||||
|
_regex_words -t ':' default 'task attributes' \
|
||||||
|
'pro*ject:Project name:$task_projects' \
|
||||||
|
'du*e:Due date:$task_dates' \
|
||||||
|
'wa*it:Date until task becomes pending:$task_dates' \
|
||||||
|
're*cur:Recurrence frequency:$task_freqs' \
|
||||||
|
'pri*ority:priority:$task_priorities' \
|
||||||
|
'un*til:Recurrence end date:$task_dates' \
|
||||||
|
'fg:Foreground color' \
|
||||||
|
'bg:Background color' \
|
||||||
|
'li*mit:Desired number of rows in report'
|
||||||
|
task_attributes=("$reply[@]")
|
||||||
|
|
||||||
|
args=(
|
||||||
|
\( "$task_attributes[@]" \|
|
||||||
|
\( /'(project|due|wait|recur|priority|until|fg|bg|limit).'/- \( /$'[^:]#:'/ ":default:modifiers:compadd -S ':' -a _task_modifiers" \) \) \|
|
||||||
|
\( /'(rc).'/- \( /$'[^:]#:'/ ":arguments:config:compadd -S ':' -a _task_config" \) \) \|
|
||||||
|
\( /'(+|-)'/- \( /"$word"/ ":values:remove tag:compadd -a _task_tags" \) \) \|
|
||||||
|
\( /"$word"/ \)
|
||||||
|
\) \#
|
||||||
|
)
|
||||||
|
_regex_arguments _task_attributes "${args[@]}"
|
||||||
|
|
||||||
|
## task commands
|
||||||
|
|
||||||
|
# default completion
|
||||||
|
(( $+functions[_task_default] )) ||
|
||||||
|
_task_default() {
|
||||||
|
_task_attributes "$@"
|
||||||
|
}
|
||||||
|
|
||||||
|
# commands expecting an ID
|
||||||
|
(( $+functions[_task_id] )) ||
|
||||||
|
_task_id() {
|
||||||
|
if (( CURRENT < 3 )); then
|
||||||
|
# update IDs
|
||||||
|
_task_zshids=( ${(f)"$(task _zshids)"} )
|
||||||
|
_describe -t values 'task IDs' _task_zshids
|
||||||
|
else
|
||||||
|
_task_attributes "$@"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# merge completion
|
||||||
|
(( $+functions[_task_merge] )) ||
|
||||||
|
_task_merge() {
|
||||||
|
# TODO match URIs in .taskrc
|
||||||
|
_files
|
||||||
|
}
|
||||||
|
|
||||||
|
# push completion
|
||||||
|
(( $+functions[_task_push] )) ||
|
||||||
|
_task_push() {
|
||||||
|
# TODO match URIs in .taskrc
|
||||||
|
_files
|
||||||
|
}
|
||||||
|
|
||||||
|
# pull completion
|
||||||
|
(( $+functions[_task_pull] )) ||
|
||||||
|
_task_pull() {
|
||||||
|
# TODO match URIs in .taskrc
|
||||||
|
_files
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
# modify (task [0-9]* ...) completion
|
||||||
|
(( $+functions[_task_modify] )) ||
|
||||||
|
_task_modify() {
|
||||||
|
_describe -t commands 'task command' _task_idCmdsDesc
|
||||||
|
_task_attributes "$@"
|
||||||
|
}
|
||||||
|
|
||||||
|
## first level completion => task sub-command completion
|
||||||
|
(( $+functions[_task_commands] )) ||
|
||||||
|
_task_commands() {
|
||||||
|
local cmd ret=1
|
||||||
|
if (( CURRENT == 1 )); then
|
||||||
|
# update IDs
|
||||||
|
_task_zshids=( ${(f)"$(task _zshids)"} )
|
||||||
|
|
||||||
|
_describe -t commands 'task command' _task_zshcmds
|
||||||
|
_describe -t values 'task IDs' _task_zshids
|
||||||
|
# TODO match more than one ID
|
||||||
|
elif [[ $words[1] =~ ^[0-9]*$ ]] then
|
||||||
|
_call_function ret _task_modify
|
||||||
|
return ret
|
||||||
|
else
|
||||||
|
# local curcontext="${curcontext}"
|
||||||
|
# cmd="${_task_cmds[(r)$words[1]:*]%%:*}"
|
||||||
|
cmd="${_task_cmds[(r)$words[1]]}"
|
||||||
|
idCmd="${(M)_task_idCmds[@]:#$words[1]}"
|
||||||
|
if (( $#cmd )); then
|
||||||
|
# curcontext="${curcontext%:*:*}:task-${cmd}"
|
||||||
|
|
||||||
|
if (( $#idCmd )); then
|
||||||
|
_call_function ret _task_id
|
||||||
|
else
|
||||||
|
_call_function ret _task_${cmd} ||
|
||||||
|
_call_function ret _task_default ||
|
||||||
|
_message "No command remaining."
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
_message "Unknown subcommand ${cmd}"
|
||||||
|
fi
|
||||||
|
return ret
|
||||||
|
fi
|
||||||
|
}
|
21
plugins/taskwarrior/taskwarrior.plugin.zsh
Normal file
21
plugins/taskwarrior/taskwarrior.plugin.zsh
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
################################################################################
|
||||||
|
# Author: Pete Clark
|
||||||
|
# Email: pete[dot]clark[at]gmail[dot]com
|
||||||
|
# Version: 0.1 (05/24/2011)
|
||||||
|
# License: WTFPL<http://sam.zoy.org/wtfpl/>
|
||||||
|
#
|
||||||
|
# This oh-my-zsh plugin adds smart tab completion for
|
||||||
|
# TaskWarrior<http://taskwarrior.org/>. It uses the zsh tab completion
|
||||||
|
# script (_task) distributed with TaskWarrior for the completion definitions.
|
||||||
|
#
|
||||||
|
# Typing task[tabtab] will give you a list of current tasks, task 66[tabtab]
|
||||||
|
# gives a list of available modifications for that task, etc.
|
||||||
|
################################################################################
|
||||||
|
|
||||||
|
zstyle ':completion:*:*:task:*' verbose yes
|
||||||
|
zstyle ':completion:*:*:task:*:descriptions' format '%U%B%d%b%u'
|
||||||
|
|
||||||
|
zstyle ':completion:*:*:task:*' group-name ''
|
||||||
|
|
||||||
|
alias t=task
|
||||||
|
compdef _task t=task
|
|
@ -1,11 +1,9 @@
|
||||||
|
alias et='mate .'
|
||||||
|
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 etts='mate app config lib db public script spec test vendor/plugins vendor/gems Rakefile Capfile Todo'
|
||||||
|
|
||||||
# TextMate
|
# Edit Ruby app in TextMate
|
||||||
alias et='mate . &'
|
|
||||||
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 etts='mate app config lib db public script spec test vendor/plugins vendor/gems Rakefile Capfile Todo &'
|
|
||||||
|
|
||||||
# Editor Ruby file 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`
|
|
@ -1,23 +1,26 @@
|
||||||
# Path to your oh-my-zsh configuration.
|
# Path to your oh-my-zsh configuration.
|
||||||
export ZSH=$HOME/.oh-my-zsh
|
ZSH=$HOME/.oh-my-zsh
|
||||||
|
|
||||||
# Set name of the theme to load.
|
# Set name of the theme to load.
|
||||||
# Look in ~/.oh-my-zsh/themes/
|
# Look in ~/.oh-my-zsh/themes/
|
||||||
# Optionally, if you set this to "random", it'll load a random theme each
|
# Optionally, if you set this to "random", it'll load a random theme each
|
||||||
# time that oh-my-zsh is loaded.
|
# time that oh-my-zsh is loaded.
|
||||||
export ZSH_THEME="robbyrussell"
|
ZSH_THEME="robbyrussell"
|
||||||
|
|
||||||
# Set to this to use case-sensitive completion
|
# Set to this to use case-sensitive completion
|
||||||
# export CASE_SENSITIVE="true"
|
# CASE_SENSITIVE="true"
|
||||||
|
|
||||||
# Comment this out to disable weekly auto-update checks
|
# Comment this out to disable weekly auto-update checks
|
||||||
# export DISABLE_AUTO_UPDATE="true"
|
# DISABLE_AUTO_UPDATE="true"
|
||||||
|
|
||||||
# Uncomment following line if you want to disable colors in ls
|
# Uncomment following line if you want to disable colors in ls
|
||||||
# export DISABLE_LS_COLORS="true"
|
# DISABLE_LS_COLORS="true"
|
||||||
|
|
||||||
# Uncomment following line if you want to disable autosetting terminal title.
|
# Uncomment following line if you want to disable autosetting terminal title.
|
||||||
# export DISABLE_AUTO_TITLE="true"
|
# DISABLE_AUTO_TITLE="true"
|
||||||
|
|
||||||
|
# Uncomment following line if you want red dots to be displayed while waiting for completion
|
||||||
|
# COMPLETION_WAITING_DOTS="true"
|
||||||
|
|
||||||
# Which plugins would you like to load? (plugins can be found in ~/.oh-my-zsh/plugins/*)
|
# Which plugins would you like to load? (plugins can be found in ~/.oh-my-zsh/plugins/*)
|
||||||
# Example format: plugins=(rails git textmate ruby lighthouse)
|
# Example format: plugins=(rails git textmate ruby lighthouse)
|
||||||
|
|
22
themes/alanpeabody.zsh-theme
Normal file
22
themes/alanpeabody.zsh-theme
Normal file
|
@ -0,0 +1,22 @@
|
||||||
|
|
||||||
|
local user='%{$fg[magenta]%}%n@%{$fg[magenta]%}%m%{$reset_color%}'
|
||||||
|
local pwd='%{$fg[blue]%}%~%{$reset_color%}'
|
||||||
|
local rvm='%{$fg[green]%}‹$(rvm-prompt i v g)›%{$reset_color%}'
|
||||||
|
local return_code='%(?..%{$fg[red]%}%? ↵%{$reset_color%})'
|
||||||
|
local git_branch='$(git_prompt_status)%{$reset_color%}$(git_prompt_info)%{$reset_color%}'
|
||||||
|
|
||||||
|
ZSH_THEME_GIT_PROMPT_PREFIX="%{$fg[green]%}"
|
||||||
|
ZSH_THEME_GIT_PROMPT_SUFFIX="%{$reset_color%}"
|
||||||
|
ZSH_THEME_GIT_PROMPT_DIRTY=""
|
||||||
|
ZSH_THEME_GIT_PROMPT_CLEAN=""
|
||||||
|
|
||||||
|
ZSH_THEME_GIT_PROMPT_ADDED="%{$fg[green]%} ✚"
|
||||||
|
ZSH_THEME_GIT_PROMPT_MODIFIED="%{$fg[blue]%} ✹"
|
||||||
|
ZSH_THEME_GIT_PROMPT_DELETED="%{$fg[red]%} ✖"
|
||||||
|
ZSH_THEME_GIT_PROMPT_RENAMED="%{$fg[magenta]%} ➜"
|
||||||
|
ZSH_THEME_GIT_PROMPT_UNMERGED="%{$fg[yellow]%} ═"
|
||||||
|
ZSH_THEME_GIT_PROMPT_UNTRACKED="%{$fg[cyan]%} ✭"
|
||||||
|
|
||||||
|
PROMPT="${user} ${pwd}$ "
|
||||||
|
RPROMPT="${return_code} ${git_branch} ${rvm}"
|
||||||
|
|
20
themes/blinks.zsh-theme
Normal file
20
themes/blinks.zsh-theme
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
# https://github.com/blinks zsh theme
|
||||||
|
|
||||||
|
function _prompt_char() {
|
||||||
|
if $(git rev-parse --is-inside-work-tree >/dev/null 2>&1); then
|
||||||
|
echo "%{%F{blue}%}±%{%f%k%b%}"
|
||||||
|
else
|
||||||
|
echo ' '
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
ZSH_THEME_GIT_PROMPT_PREFIX=" [%{%B%F{blue}%}"
|
||||||
|
ZSH_THEME_GIT_PROMPT_SUFFIX="%{%f%k%b%K{black}%B%F{green}%}]"
|
||||||
|
ZSH_THEME_GIT_PROMPT_DIRTY=" %{%F{red}%}*%{%f%k%b%}"
|
||||||
|
ZSH_THEME_GIT_PROMPT_CLEAN=""
|
||||||
|
|
||||||
|
PROMPT='%{%f%k%b%}
|
||||||
|
%{%K{black}%B%F{green}%}%n%{%B%F{blue}%}@%{%B%F{cyan}%}%m%{%B%F{green}%} %{%b%F{yellow}%K{black}%}%~%{%B%F{green}%}$(git_prompt_info)%E%{%f%k%b%}
|
||||||
|
%{%K{black}%}$(_prompt_char)%{%K{black}%} %#%{%f%k%b%} '
|
||||||
|
|
||||||
|
RPROMPT='!%{%B%F{cyan}%}%!%{%f%k%b%}'
|
14
themes/dpoggi.zsh-theme
Normal file
14
themes/dpoggi.zsh-theme
Normal file
|
@ -0,0 +1,14 @@
|
||||||
|
if [ $UID -eq 0 ]; then NCOLOR="red"; else NCOLOR="green"; fi
|
||||||
|
local return_code="%(?..%{$fg[red]%}%? ↵%{$reset_color%})"
|
||||||
|
|
||||||
|
PROMPT='%{$fg[$NCOLOR]%}%n%{$reset_color%}@%{$fg[cyan]%}%m\
|
||||||
|
%{$reset_color%}:%{$fg[magenta]%}%~\
|
||||||
|
$(git_prompt_info) \
|
||||||
|
%{$fg[red]%}%(!.#.»)%{$reset_color%} '
|
||||||
|
PROMPT2='%{$fg[red]%}\ %{$reset_color%}'
|
||||||
|
RPS1='${return_code}'
|
||||||
|
|
||||||
|
ZSH_THEME_GIT_PROMPT_PREFIX="%{$fg[yellow]%}("
|
||||||
|
ZSH_THEME_GIT_PROMPT_CLEAN="%{$fg[green]%}○%{$reset_color%}"
|
||||||
|
ZSH_THEME_GIT_PROMPT_DIRTY="%{$fg[red]%}⚡%{$reset_color%}"
|
||||||
|
ZSH_THEME_GIT_PROMPT_SUFFIX="%{$fg[yellow]%})%{$reset_color%}"
|
|
@ -3,7 +3,18 @@
|
||||||
local user_color='green'; [ $UID -eq 0 ] && user_color='red'
|
local user_color='green'; [ $UID -eq 0 ] && user_color='red'
|
||||||
PROMPT='%n@%m %{$fg[$user_color]%}%~%{$reset_color%}%(!.#.>) '
|
PROMPT='%n@%m %{$fg[$user_color]%}%~%{$reset_color%}%(!.#.>) '
|
||||||
PROMPT2='%{$fg[red]%}\ %{$reset_color%}'
|
PROMPT2='%{$fg[red]%}\ %{$reset_color%}'
|
||||||
RPS1='%(?..%{$fg[red]%}%? ↵%{$reset_color%})$(git_prompt_info)'
|
|
||||||
|
|
||||||
ZSH_THEME_GIT_PROMPT_PREFIX=" %{$fg[cyan]%}"
|
local return_status="%{$fg_bold[red]%}%(?..%?)%{$reset_color%}"
|
||||||
ZSH_THEME_GIT_PROMPT_SUFFIX="%{$reset_color%}"
|
RPROMPT='${return_status}$(git_prompt_info)$(git_prompt_status)%{$reset_color%}'
|
||||||
|
|
||||||
|
ZSH_THEME_GIT_PROMPT_PREFIX=" "
|
||||||
|
ZSH_THEME_GIT_PROMPT_SUFFIX=""
|
||||||
|
ZSH_THEME_GIT_PROMPT_DIRTY=""
|
||||||
|
ZSH_THEME_GIT_PROMPT_CLEAN=""
|
||||||
|
|
||||||
|
ZSH_THEME_GIT_PROMPT_ADDED="%{$fg_bold[green]%}+"
|
||||||
|
ZSH_THEME_GIT_PROMPT_MODIFIED="%{$fg_bold[blue]%}!"
|
||||||
|
ZSH_THEME_GIT_PROMPT_DELETED="%{$fg_bold[red]%}-"
|
||||||
|
ZSH_THEME_GIT_PROMPT_RENAMED="%{$fg_bold[magenta]%}>"
|
||||||
|
ZSH_THEME_GIT_PROMPT_UNMERGED="%{$fg_bold[yellow]%}#"
|
||||||
|
ZSH_THEME_GIT_PROMPT_UNTRACKED="%{$fg_bold[cyan]%}?"
|
||||||
|
|
6
themes/fwalch.zsh-theme
Normal file
6
themes/fwalch.zsh-theme
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
PROMPT='%{$fg_bold[green]%}%p %{$fg[cyan]%}%c%{$fg_bold[blue]%}$(git_prompt_info)%{$fg_bold[blue]%} % %{$reset_color%}'
|
||||||
|
|
||||||
|
ZSH_THEME_GIT_PROMPT_PREFIX=" (%{$fg[red]%}"
|
||||||
|
ZSH_THEME_GIT_PROMPT_SUFFIX="%{$reset_color%}"
|
||||||
|
ZSH_THEME_GIT_PROMPT_DIRTY="%{$fg[blue]%}) %{$fg[yellow]%}✗%{$reset_color%}"
|
||||||
|
ZSH_THEME_GIT_PROMPT_CLEAN="%{$fg[blue]%})"
|
26
themes/humza.zsh-theme
Normal file
26
themes/humza.zsh-theme
Normal file
|
@ -0,0 +1,26 @@
|
||||||
|
# ZSH THEME Preview: https://skitch.com/huyy/rk979/humza.zshtheme
|
||||||
|
|
||||||
|
let TotalBytes=0
|
||||||
|
for Bytes in $(ls -l | grep "^-" | awk '{ print $5 }')
|
||||||
|
do
|
||||||
|
let TotalBytes=$TotalBytes+$Bytes
|
||||||
|
done
|
||||||
|
# should it say b, kb, Mb, or Gb
|
||||||
|
if [ $TotalBytes -lt 1024 ]; then
|
||||||
|
TotalSize=$(echo -e "scale=3 \n$TotalBytes \nquit" | bc)
|
||||||
|
suffix="b"
|
||||||
|
elif [ $TotalBytes -lt 1048576 ]; then
|
||||||
|
TotalSize=$(echo -e "scale=3 \n$TotalBytes/1024 \nquit" | bc)
|
||||||
|
suffix="kb"
|
||||||
|
elif [ $TotalBytes -lt 1073741824 ]; then
|
||||||
|
TotalSize=$(echo -e "scale=3 \n$TotalBytes/1048576 \nquit" | bc)
|
||||||
|
suffix="Mb"
|
||||||
|
else
|
||||||
|
TotalSize=$(echo -e "scale=3 \n$TotalBytes/1073741824 \nquit" | bc)
|
||||||
|
suffix="Gb"
|
||||||
|
fi
|
||||||
|
|
||||||
|
PROMPT='%{$reset_color%}%n %{$fg[green]%}{%{$reset_color%}%~%{$fg[green]%}}%{$reset_color%}$(git_prompt_info) greetings, earthling %{$fg[green]%}[%{$reset_color%}%{$TotalSize%}%{$suffix%}%{$fg[green]%}]%{$fg[red]%}$%{$reset_color%} ☞ '
|
||||||
|
|
||||||
|
ZSH_THEME_GIT_PROMPT_PREFIX="%{$fg[red]%}±("
|
||||||
|
ZSH_THEME_GIT_PROMPT_SUFFIX=");%{$reset_color%}"
|
4
themes/jispwoso.zsh-theme
Normal file
4
themes/jispwoso.zsh-theme
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
PROMPT=$'%{$fg[green]%}%n@%m: %{$reset_color%}%{$fg[blue]%}%/%{$reset_color%}
|
||||||
|
%{$fg_bold[red]%}➜ %{$reset_color%} '
|
||||||
|
|
||||||
|
PROMPT2="%{$fg_blod[black]%}%_> %{$reset_color%}"
|
|
@ -1,6 +1,6 @@
|
||||||
#PROMPT='%{$fg_bold[red]%}➜ %{$fg_bold[green]%}%p %{$fg[cyan]%}%c %{$fg_bold[blue]%}$(git_prompt_info)%{$fg_bold[blue]%} % %{$reset_color%}'
|
#PROMPT='%{$fg_bold[red]%}➜ %{$fg_bold[green]%}%p %{$fg[cyan]%}%c %{$fg_bold[blue]%}$(git_prompt_info)%{$fg_bold[blue]%} % %{$reset_color%}'
|
||||||
PROMPT="%{$fg_bold[cyan]%}%T%{$fg_bold[green]%} %{$fg_bold[white]%}%n%{$fg[magenta]%}@%{$fg_bold[white]%}%m %{$fg_bold[green]%}%d
|
PROMPT="%{$fg_bold[cyan]%}%T%{$fg_bold[green]%} %{$fg_bold[white]%}%n%{$fg[magenta]%}@%{$fg_bold[white]%}%m %{$fg_bold[green]%}%d
|
||||||
%{$fg_bold[yellow]%}%% $(git_prompt_info)%{$reset_color%}"
|
%{$fg_bold[yellow]%}%% %{$reset_color%}"
|
||||||
|
|
||||||
#ZSH_THEME_GIT_PROMPT_PREFIX="git:(%{$fg[red]%}"
|
#ZSH_THEME_GIT_PROMPT_PREFIX="git:(%{$fg[red]%}"
|
||||||
#ZSH_THEME_GIT_PROMPT_SUFFIX="%{$reset_color%}"
|
#ZSH_THEME_GIT_PROMPT_SUFFIX="%{$reset_color%}"
|
||||||
|
|
|
@ -3,8 +3,22 @@
|
||||||
|
|
||||||
local return_code="%(?..%{$fg_bold[red]%}%? ↵%{$reset_color%})"
|
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 '
|
function my_git_prompt_info() {
|
||||||
|
ref=$(git symbolic-ref HEAD 2> /dev/null) || return
|
||||||
|
GIT_STATUS=$(git_prompt_status)
|
||||||
|
[[ -n $GIT_STATUS ]] && GIT_STATUS=" $GIT_STATUS"
|
||||||
|
echo "$ZSH_THEME_GIT_PROMPT_PREFIX${ref#refs/heads/}$GIT_STATUS$ZSH_THEME_GIT_PROMPT_SUFFIX"
|
||||||
|
}
|
||||||
|
|
||||||
|
PROMPT='%{$fg_bold[green]%}%n@%m%{$reset_color%} %{$fg_bold[blue]%}%2~%{$reset_color%} $(my_git_prompt_info)%{$reset_color%}%B»%b '
|
||||||
RPS1="${return_code}"
|
RPS1="${return_code}"
|
||||||
|
|
||||||
ZSH_THEME_GIT_PROMPT_PREFIX="%{$fg[yellow]%}("
|
ZSH_THEME_GIT_PROMPT_PREFIX="%{$fg[yellow]%}("
|
||||||
ZSH_THEME_GIT_PROMPT_SUFFIX=") %{$reset_color%}"
|
ZSH_THEME_GIT_PROMPT_SUFFIX=") %{$reset_color%}"
|
||||||
|
ZSH_THEME_GIT_PROMPT_UNTRACKED="%%"
|
||||||
|
ZSH_THEME_GIT_PROMPT_ADDED="+"
|
||||||
|
ZSH_THEME_GIT_PROMPT_MODIFIED="*"
|
||||||
|
ZSH_THEME_GIT_PROMPT_RENAMED="~"
|
||||||
|
ZSH_THEME_GIT_PROMPT_DELETED="!"
|
||||||
|
ZSH_THEME_GIT_PROMPT_UNMERGED="?"
|
||||||
|
|
||||||
|
|
8
themes/miloshadzic.zsh-theme
Normal file
8
themes/miloshadzic.zsh-theme
Normal file
|
@ -0,0 +1,8 @@
|
||||||
|
# Yay! High voltage and arrows!
|
||||||
|
|
||||||
|
ZSH_THEME_GIT_PROMPT_PREFIX="%{$reset_color%}%{$fg[green]%}"
|
||||||
|
ZSH_THEME_GIT_PROMPT_SUFFIX="%{$reset_color%} "
|
||||||
|
ZSH_THEME_GIT_PROMPT_DIRTY="%{$fg[yellow]%}⚡%{$reset_color%}"
|
||||||
|
ZSH_THEME_GIT_PROMPT_CLEAN=""
|
||||||
|
|
||||||
|
PROMPT='%{$fg[cyan]%}%1~%{$reset_color%}%{$fg[red]%}|%{$reset_color%}$(git_prompt_info)%{$fg[cyan]%}⇒%{$reset_color%} '
|
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 '
|
17
themes/nebirhos.zsh-theme
Normal file
17
themes/nebirhos.zsh-theme
Normal file
|
@ -0,0 +1,17 @@
|
||||||
|
# Based on robbyrussell's theme, with host and rvm indicators. Example:
|
||||||
|
# @host ➜ currentdir rvm:(rubyversion@gemset) git:(branchname)
|
||||||
|
|
||||||
|
# Get the current ruby version in use with RVM:
|
||||||
|
if [ -e ~/.rvm/bin/rvm-prompt ]; then
|
||||||
|
RUBY_PROMPT_="%{$fg_bold[blue]%}rvm:(%{$fg[green]%}\$(~/.rvm/bin/rvm-prompt s i v g)%{$fg_bold[blue]%})%{$reset_color%} "
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Get the host name (first 4 chars)
|
||||||
|
HOST_PROMPT_="%{$fg_bold[red]%}@$HOST[0,4] ➜ %{$fg_bold[cyan]%}%c "
|
||||||
|
GIT_PROMPT="%{$fg_bold[blue]%}\$(git_prompt_info)%{$fg_bold[blue]%} % %{$reset_color%}"
|
||||||
|
PROMPT="$HOST_PROMPT_$RUBY_PROMPT_$GIT_PROMPT"
|
||||||
|
|
||||||
|
ZSH_THEME_GIT_PROMPT_PREFIX="git:(%{$fg[red]%}"
|
||||||
|
ZSH_THEME_GIT_PROMPT_SUFFIX="%{$reset_color%}"
|
||||||
|
ZSH_THEME_GIT_PROMPT_DIRTY="%{$fg[blue]%}) %{$fg[yellow]%}✗%{$reset_color%}"
|
||||||
|
ZSH_THEME_GIT_PROMPT_CLEAN="%{$fg[blue]%})"
|
11
themes/obraun.zsh-theme
Normal file
11
themes/obraun.zsh-theme
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
if [ "$(whoami)" = "root" ]; then CARETCOLOR="red"; else CARETCOLOR="blue"; fi
|
||||||
|
|
||||||
|
local return_code="%(?..%{$fg[red]%}%? ↵%{$reset_color%})"
|
||||||
|
|
||||||
|
PROMPT='%{$fg[green]%}[%*]%{$reset_color%} %{$fg_no_bold[cyan]%}%n %{${fg_bold[blue]}%}::%{$reset_color%} %{$fg[yellow]%}%m%{$reset_color%} %{$fg_no_bold[magenta]%} ➜ %{$reset_color%} %{${fg[green]}%}%3~ $(git_prompt_info)%{${fg_bold[$CARETCOLOR]}%}»%{${reset_color}%} '
|
||||||
|
|
||||||
|
RPS1="${return_code}"
|
||||||
|
|
||||||
|
ZSH_THEME_GIT_PROMPT_PREFIX="%{$fg[red]%}‹"
|
||||||
|
ZSH_THEME_GIT_PROMPT_SUFFIX="› %{$reset_color%}"
|
||||||
|
|
|
@ -7,8 +7,8 @@ RPROMPT='[%*]'
|
||||||
ZSH_THEME_GIT_PROMPT_PREFIX="%{$fg_bold[blue]%}(%{$fg_no_bold[red]%}%B"
|
ZSH_THEME_GIT_PROMPT_PREFIX="%{$fg_bold[blue]%}(%{$fg_no_bold[red]%}%B"
|
||||||
ZSH_THEME_GIT_PROMPT_SUFFIX="%b%{$fg_bold[blue]%})%{$reset_color%} "
|
ZSH_THEME_GIT_PROMPT_SUFFIX="%b%{$fg_bold[blue]%})%{$reset_color%} "
|
||||||
ZSH_THEME_GIT_PROMPT_CLEAN=""
|
ZSH_THEME_GIT_PROMPT_CLEAN=""
|
||||||
ZSH_THEME_GIT_PROMPT_DIRTY="%{$fg_bold[red]%}"
|
ZSH_THEME_GIT_PROMPT_DIRTY="*"
|
||||||
|
|
||||||
# LS colors, made with http://geoff.greer.fm/lscolors/
|
# LS colors, made with http://geoff.greer.fm/lscolors/
|
||||||
export LSCOLORS="Gxfxcxdxbxegedabagacad"
|
export LSCOLORS="Gxfxcxdxbxegedabagacad"
|
||||||
export LS_COLORS='no=00:fi=00:di=01;34:ln=00;36:pi=40;33:so=01;35:do=01;35:bd=40;33;01:cd=40;33;01:or=41;33;01:ex=00;32:*.cmd=00;32:*.exe=01;32:*.com=01;32:*.bat=01;32:*.btm=01;32:*.dll=01;32:*.tar=00;31:*.tbz=00;31:*.tgz=00;31:*.rpm=00;31:*.deb=00;31:*.arj=00;31:*.taz=00;31:*.lzh=00;31:*.lzma=00;31:*.zip=00;31:*.zoo=00;31:*.z=00;31:*.Z=00;31:*.gz=00;31:*.bz2=00;31:*.tb2=00;31:*.tz2=00;31:*.tbz2=00;31:*.avi=01;35:*.bmp=01;35:*.fli=01;35:*.gif=01;35:*.jpg=01;35:*.jpeg=01;35:*.mng=01;35:*.mov=01;35:*.mpg=01;35:*.pcx=01;35:*.pbm=01;35:*.pgm=01;35:*.png=01;35:*.ppm=01;35:*.tga=01;35:*.tif=01;35:*.xbm=01;35:*.xpm=01;35:*.dl=01;35:*.gl=01;35:*.wmv=01;35:*.aiff=00;32:*.au=00;32:*.mid=00;32:*.mp3=00;32:*.ogg=00;32:*.voc=00;32:*.wav=00;32:'
|
export LS_COLORS='no=00:fi=00:di=01;34:ln=00;36:pi=40;33:so=01;35:do=01;35:bd=40;33;01:cd=40;33;01:or=41;33;01:ex=00;32:*.cmd=00;32:*.exe=01;32:*.com=01;32:*.bat=01;32:*.btm=01;32:*.dll=01;32:*.tar=00;31:*.tbz=00;31:*.tgz=00;31:*.rpm=00;31:*.deb=00;31:*.arj=00;31:*.taz=00;31:*.lzh=00;31:*.lzma=00;31:*.zip=00;31:*.zoo=00;31:*.z=00;31:*.Z=00;31:*.gz=00;31:*.bz2=00;31:*.tb2=00;31:*.tz2=00;31:*.tbz2=00;31:*.avi=01;35:*.bmp=01;35:*.fli=01;35:*.gif=01;35:*.jpg=01;35:*.jpeg=01;35:*.mng=01;35:*.mov=01;35:*.mpg=01;35:*.pcx=01;35:*.pbm=01;35:*.pgm=01;35:*.png=01;35:*.ppm=01;35:*.tga=01;35:*.tif=01;35:*.xbm=01;35:*.xpm=01;35:*.dl=01;35:*.gl=01;35:*.wmv=01;35:*.aiff=00;32:*.au=00;32:*.mid=00;32:*.mp3=00;32:*.ogg=00;32:*.voc=00;32:*.wav=00;32:*.patch=00;34:*.o=00;32:*.so=01;35:*.ko=01;31:*.la=00;33'
|
||||||
|
|
15
themes/re5et.zsh-theme
Normal file
15
themes/re5et.zsh-theme
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
if [ "$(whoami)" = "root" ]; then CARETCOLOR="red"; else CARETCOLOR="magenta"; fi
|
||||||
|
|
||||||
|
local return_code="%(?..%{$fg_bold[red]%}:( %?%{$reset_color%})"
|
||||||
|
|
||||||
|
PROMPT='
|
||||||
|
%{$fg_bold[cyan]%}%n%{$reset_color%}%{$fg[yellow]%}@%{$reset_color%}%{$fg_bold[blue]%}%m%{$reset_color%}:%{${fg_bold[green]}%}%~%{$reset_color%}$(git_prompt_info)
|
||||||
|
%{${fg[$CARETCOLOR]}%}%# %{${reset_color}%}'
|
||||||
|
|
||||||
|
RPS1='${return_code} %D - %*'
|
||||||
|
|
||||||
|
ZSH_THEME_GIT_PROMPT_PREFIX="%{$fg_bold[magenta]%}^%{$reset_color%}%{$fg_bold[yellow]%}"
|
||||||
|
ZSH_THEME_GIT_PROMPT_SUFFIX="%{$reset_color%}"
|
||||||
|
ZSH_THEME_GIT_PROMPT_DIRTY="%{$fg_bold[red]%} ±"
|
||||||
|
ZSH_THEME_GIT_PROMPT_UNTRACKED="%{$fg[cyan]%} ?"
|
||||||
|
ZSH_THEME_GIT_PROMPT_CLEAN="%{$fg_bold[red]%} ♥"
|
6
themes/simple.zsh-theme
Normal file
6
themes/simple.zsh-theme
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
PROMPT='%{$fg[green]%}%~%{$fg_bold[blue]%}$(git_prompt_info)%{$reset_color%} '
|
||||||
|
|
||||||
|
ZSH_THEME_GIT_PROMPT_PREFIX="("
|
||||||
|
ZSH_THEME_GIT_PROMPT_SUFFIX=")"
|
||||||
|
ZSH_THEME_GIT_PROMPT_DIRTY=" ✗"
|
||||||
|
ZSH_THEME_GIT_PROMPT_CLEAN=" ✔"
|
91
themes/smt.zsh-theme
Normal file
91
themes/smt.zsh-theme
Normal file
|
@ -0,0 +1,91 @@
|
||||||
|
# -----------------------------------------------------------------------------
|
||||||
|
# FILE: smt.zsh-theme
|
||||||
|
# DESCRIPTION: oh-my-zsh theme file, based on dogenpunk by Matthew Nelson.
|
||||||
|
# AUTHOR: Stephen Tudor (stephen@tudorstudio.com
|
||||||
|
# VERSION: 0.1
|
||||||
|
# SCREENSHOT: coming soon
|
||||||
|
# -----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
MODE_INDICATOR="%{$fg_bold[red]%}❮%{$reset_color%}%{$fg[red]%}❮❮%{$reset_color%}"
|
||||||
|
local return_status="%{$fg[red]%}%(?..⏎)%{$reset_color%} "
|
||||||
|
|
||||||
|
ZSH_THEME_GIT_PROMPT_PREFIX="|"
|
||||||
|
ZSH_THEME_GIT_PROMPT_SUFFIX="%{$reset_color%}"
|
||||||
|
ZSH_THEME_GIT_PROMPT_DIRTY="%{$fg_bold[red]%}⚡%{$reset_color%}"
|
||||||
|
ZSH_THEME_GIT_PROMPT_AHEAD="%{$fg_bold[red]%}!%{$reset_color%}"
|
||||||
|
ZSH_THEME_GIT_PROMPT_CLEAN="%{$fg_bold[green]%}✓%{$reset_color%}"
|
||||||
|
|
||||||
|
ZSH_THEME_GIT_PROMPT_ADDED="%{$fg[green]%} ✚"
|
||||||
|
ZSH_THEME_GIT_PROMPT_MODIFIED="%{$fg[blue]%} ✹"
|
||||||
|
ZSH_THEME_GIT_PROMPT_DELETED="%{$fg[red]%} ✖"
|
||||||
|
ZSH_THEME_GIT_PROMPT_RENAMED="%{$fg[magenta]%} ➜"
|
||||||
|
ZSH_THEME_GIT_PROMPT_UNMERGED="%{$fg[yellow]%} ═"
|
||||||
|
ZSH_THEME_GIT_PROMPT_UNTRACKED="%{$fg[cyan]%} ✭"
|
||||||
|
|
||||||
|
# Format for git_prompt_long_sha() and git_prompt_short_sha()
|
||||||
|
ZSH_THEME_GIT_PROMPT_SHA_BEFORE="➤ %{$fg_bold[yellow]%}"
|
||||||
|
ZSH_THEME_GIT_PROMPT_SHA_AFTER="%{$reset_color%}"
|
||||||
|
|
||||||
|
function prompt_char() {
|
||||||
|
git branch >/dev/null 2>/dev/null && echo "%{$fg[green]%}±%{$reset_color%}" && return
|
||||||
|
hg root >/dev/null 2>/dev/null && echo "%{$fg_bold[red]%}☿%{$reset_color%}" && return
|
||||||
|
echo "%{$fg[cyan]%}◯%{$reset_color%}"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Colors vary depending on time lapsed.
|
||||||
|
ZSH_THEME_GIT_TIME_SINCE_COMMIT_SHORT="%{$fg[green]%}"
|
||||||
|
ZSH_THEME_GIT_TIME_SHORT_COMMIT_MEDIUM="%{$fg[yellow]%}"
|
||||||
|
ZSH_THEME_GIT_TIME_SINCE_COMMIT_LONG="%{$fg[red]%}"
|
||||||
|
ZSH_THEME_GIT_TIME_SINCE_COMMIT_NEUTRAL="%{$fg[cyan]%}"
|
||||||
|
|
||||||
|
# Determine the time since last commit. If branch is clean,
|
||||||
|
# use a neutral color, otherwise colors will vary according to time.
|
||||||
|
function git_time_since_commit() {
|
||||||
|
if git rev-parse --git-dir > /dev/null 2>&1; then
|
||||||
|
# Only proceed if there is actually a commit.
|
||||||
|
if [[ $(git log 2>&1 > /dev/null | grep -c "^fatal: bad default revision") == 0 ]]; then
|
||||||
|
# Get the last commit.
|
||||||
|
last_commit=`git log --pretty=format:'%at' -1 2> /dev/null`
|
||||||
|
now=`date +%s`
|
||||||
|
seconds_since_last_commit=$((now-last_commit))
|
||||||
|
|
||||||
|
# Totals
|
||||||
|
MINUTES=$((seconds_since_last_commit / 60))
|
||||||
|
HOURS=$((seconds_since_last_commit/3600))
|
||||||
|
|
||||||
|
# Sub-hours and sub-minutes
|
||||||
|
DAYS=$((seconds_since_last_commit / 86400))
|
||||||
|
SUB_HOURS=$((HOURS % 24))
|
||||||
|
SUB_MINUTES=$((MINUTES % 60))
|
||||||
|
|
||||||
|
if [[ -n $(git status -s 2> /dev/null) ]]; then
|
||||||
|
if [ "$MINUTES" -gt 30 ]; then
|
||||||
|
COLOR="$ZSH_THEME_GIT_TIME_SINCE_COMMIT_LONG"
|
||||||
|
elif [ "$MINUTES" -gt 10 ]; then
|
||||||
|
COLOR="$ZSH_THEME_GIT_TIME_SHORT_COMMIT_MEDIUM"
|
||||||
|
else
|
||||||
|
COLOR="$ZSH_THEME_GIT_TIME_SINCE_COMMIT_SHORT"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
COLOR="$ZSH_THEME_GIT_TIME_SINCE_COMMIT_NEUTRAL"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$HOURS" -gt 24 ]; then
|
||||||
|
echo "[$COLOR${DAYS}d${SUB_HOURS}h${SUB_MINUTES}m%{$reset_color%}]"
|
||||||
|
elif [ "$MINUTES" -gt 60 ]; then
|
||||||
|
echo "[$COLOR${HOURS}h${SUB_MINUTES}m%{$reset_color%}]"
|
||||||
|
else
|
||||||
|
echo "[$COLOR${MINUTES}m%{$reset_color%}]"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
COLOR="$ZSH_THEME_GIT_TIME_SINCE_COMMIT_NEUTRAL"
|
||||||
|
echo "[$COLOR~]"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
PROMPT='
|
||||||
|
%{$fg[blue]%}%m%{$reset_color%} 福 %{$fg[cyan]%}%~ %{$reset_color%}$(git_prompt_short_sha)$(git_prompt_info)
|
||||||
|
%{$fg[red]%}%!%{$reset_color%} $(prompt_char) : '
|
||||||
|
|
||||||
|
RPROMPT='${return_status}$(git_time_since_commit)$(git_prompt_status)%{$reset_color%}'
|
100
themes/steeef.zsh-theme
Normal file
100
themes/steeef.zsh-theme
Normal file
|
@ -0,0 +1,100 @@
|
||||||
|
# prompt style and colors based on Steve Losh's Prose theme:
|
||||||
|
# http://github.com/sjl/oh-my-zsh/blob/master/themes/prose.zsh-theme
|
||||||
|
#
|
||||||
|
# vcs_info modifications from Bart Trojanowski's zsh prompt:
|
||||||
|
# http://www.jukie.net/bart/blog/pimping-out-zsh-prompt
|
||||||
|
#
|
||||||
|
# git untracked files modification from Brian Carper:
|
||||||
|
# http://briancarper.net/blog/570/git-info-in-your-zsh-prompt
|
||||||
|
|
||||||
|
function virtualenv_info {
|
||||||
|
[ $VIRTUAL_ENV ] && echo '('`basename $VIRTUAL_ENV`') '
|
||||||
|
}
|
||||||
|
PR_GIT_UPDATE=1
|
||||||
|
|
||||||
|
setopt prompt_subst
|
||||||
|
autoload colors
|
||||||
|
colors
|
||||||
|
|
||||||
|
autoload -U add-zsh-hook
|
||||||
|
autoload -Uz vcs_info
|
||||||
|
|
||||||
|
#use extended color pallete if available
|
||||||
|
if [[ $TERM = *256color* || $TERM = *rxvt* ]]; then
|
||||||
|
turquoise="%F{81}"
|
||||||
|
orange="%F{166}"
|
||||||
|
purple="%F{135}"
|
||||||
|
hotpink="%F{161}"
|
||||||
|
limegreen="%F{118}"
|
||||||
|
else
|
||||||
|
turquoise="$fg[cyan]"
|
||||||
|
orange="$fg[yellow]"
|
||||||
|
purple="$fg[magenta]"
|
||||||
|
hotpink="$fg[red]"
|
||||||
|
limegreen="$fg[green]"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# enable VCS systems you use
|
||||||
|
zstyle ':vcs_info:*' enable git svn
|
||||||
|
|
||||||
|
# check-for-changes can be really slow.
|
||||||
|
# you should disable it, if you work with large repositories
|
||||||
|
zstyle ':vcs_info:*:prompt:*' check-for-changes true
|
||||||
|
|
||||||
|
# set formats
|
||||||
|
# %b - branchname
|
||||||
|
# %u - unstagedstr (see below)
|
||||||
|
# %c - stagedstr (see below)
|
||||||
|
# %a - action (e.g. rebase-i)
|
||||||
|
# %R - repository path
|
||||||
|
# %S - path in the repository
|
||||||
|
PR_RST="%{${reset_color}%}"
|
||||||
|
FMT_BRANCH="(%{$turquoise%}%b%u%c${PR_RST})"
|
||||||
|
FMT_ACTION="(%{$limegreen%}%a${PR_RST})"
|
||||||
|
FMT_UNSTAGED="%{$orange%}●"
|
||||||
|
FMT_STAGED="%{$limegreen%}●"
|
||||||
|
|
||||||
|
zstyle ':vcs_info:*:prompt:*' unstagedstr "${FMT_UNSTAGED}"
|
||||||
|
zstyle ':vcs_info:*:prompt:*' stagedstr "${FMT_STAGED}"
|
||||||
|
zstyle ':vcs_info:*:prompt:*' actionformats "${FMT_BRANCH}${FMT_ACTION}"
|
||||||
|
zstyle ':vcs_info:*:prompt:*' formats "${FMT_BRANCH}"
|
||||||
|
zstyle ':vcs_info:*:prompt:*' nvcsformats ""
|
||||||
|
|
||||||
|
|
||||||
|
function steeef_preexec {
|
||||||
|
case "$(history $HISTCMD)" in
|
||||||
|
*git*)
|
||||||
|
PR_GIT_UPDATE=1
|
||||||
|
;;
|
||||||
|
*svn*)
|
||||||
|
PR_GIT_UPDATE=1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
add-zsh-hook preexec steeef_preexec
|
||||||
|
|
||||||
|
function steeef_chpwd {
|
||||||
|
PR_GIT_UPDATE=1
|
||||||
|
}
|
||||||
|
add-zsh-hook chpwd steeef_chpwd
|
||||||
|
|
||||||
|
function steeef_precmd {
|
||||||
|
if [[ -n "$PR_GIT_UPDATE" ]] ; then
|
||||||
|
# check for untracked files or updated submodules, since vcs_info doesn't
|
||||||
|
if [[ ! -z $(git ls-files --other --exclude-standard 2> /dev/null) ]]; then
|
||||||
|
PR_GIT_UPDATE=1
|
||||||
|
FMT_BRANCH="(%{$turquoise%}%b%u%c%{$hotpink%}●${PR_RST})"
|
||||||
|
else
|
||||||
|
FMT_BRANCH="(%{$turquoise%}%b%u%c${PR_RST})"
|
||||||
|
fi
|
||||||
|
zstyle ':vcs_info:*:prompt:*' formats "${FMT_BRANCH}"
|
||||||
|
|
||||||
|
vcs_info 'prompt'
|
||||||
|
PR_GIT_UPDATE=
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
add-zsh-hook precmd steeef_precmd
|
||||||
|
|
||||||
|
PROMPT=$'
|
||||||
|
%{$purple%}%n%{$reset_color%} at %{$orange%}%m%{$reset_color%} in %{$limegreen%}%~%{$reset_color%} $vcs_info_msg_0_
|
||||||
|
$(virtualenv_info)$ '
|
26
themes/sunaku.zsh-theme
Normal file
26
themes/sunaku.zsh-theme
Normal file
|
@ -0,0 +1,26 @@
|
||||||
|
# Git-centric variation of the "fishy" theme.
|
||||||
|
# See screenshot at http://ompldr.org/vOHcwZg
|
||||||
|
|
||||||
|
ZSH_THEME_GIT_PROMPT_ADDED="%{$fg[green]%}+"
|
||||||
|
ZSH_THEME_GIT_PROMPT_MODIFIED="%{$fg[magenta]%}!"
|
||||||
|
ZSH_THEME_GIT_PROMPT_DELETED="%{$fg[red]%}-"
|
||||||
|
ZSH_THEME_GIT_PROMPT_RENAMED="%{$fg[blue]%}>"
|
||||||
|
ZSH_THEME_GIT_PROMPT_UNMERGED="%{$fg[cyan]%}#"
|
||||||
|
ZSH_THEME_GIT_PROMPT_UNTRACKED="%{$fg[yellow]%}?"
|
||||||
|
|
||||||
|
ZSH_THEME_GIT_PROMPT_PREFIX=""
|
||||||
|
ZSH_THEME_GIT_PROMPT_SUFFIX=" "
|
||||||
|
ZSH_THEME_GIT_PROMPT_DIRTY=""
|
||||||
|
ZSH_THEME_GIT_PROMPT_CLEAN=""
|
||||||
|
|
||||||
|
local user_color='green'
|
||||||
|
test $UID -eq 0 && user_color='red'
|
||||||
|
|
||||||
|
PROMPT='%(?..%{$fg_bold[red]%}exit %?
|
||||||
|
%{$reset_color%})'\
|
||||||
|
'%{$bold_color%}$(git_prompt_status)%{$reset_color%}'\
|
||||||
|
'$(git_prompt_info)'\
|
||||||
|
'%{$fg[$user_color]%}%~%{$reset_color%}'\
|
||||||
|
'%(!.#.>) '
|
||||||
|
|
||||||
|
PROMPT2='%{$fg[red]%}\ %{$reset_color%}'
|
96
themes/sunrise.zsh-theme
Normal file
96
themes/sunrise.zsh-theme
Normal file
|
@ -0,0 +1,96 @@
|
||||||
|
#-------------------------------------------------------------------------------
|
||||||
|
# Sunrise theme for oh-my-zsh by Adam Lindberg (eproxus@gmail.com)
|
||||||
|
# Intended to be used with Solarized: http://ethanschoonover.com/solarized
|
||||||
|
# (Needs Git plugin for current_branch method)
|
||||||
|
#-------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
# Color shortcuts
|
||||||
|
R=$fg[red]
|
||||||
|
G=$fg[green]
|
||||||
|
M=$fg[magenta]
|
||||||
|
RB=$fg_bold[red]
|
||||||
|
YB=$fg_bold[yellow]
|
||||||
|
BB=$fg_bold[blue]
|
||||||
|
RESET=$reset_color
|
||||||
|
|
||||||
|
if [ "$(whoami)" = "root" ]; then
|
||||||
|
PROMPTCOLOR="%{$RB%}" PREFIX="-!-";
|
||||||
|
else
|
||||||
|
PROMPTCOLOR="" PREFIX="---";
|
||||||
|
fi
|
||||||
|
|
||||||
|
local return_code="%(?..%{$R%}%? ↵%{$RESET%})"
|
||||||
|
|
||||||
|
# Get the status of the working tree (copied and modified from git.zsh)
|
||||||
|
custom_git_prompt_status() {
|
||||||
|
INDEX=$(git status --porcelain 2> /dev/null)
|
||||||
|
STATUS=""
|
||||||
|
# Non-staged
|
||||||
|
if $(echo "$INDEX" | grep '^?? ' &> /dev/null); then
|
||||||
|
STATUS="$ZSH_THEME_GIT_PROMPT_UNTRACKED$STATUS"
|
||||||
|
fi
|
||||||
|
if $(echo "$INDEX" | grep '^UU ' &> /dev/null); then
|
||||||
|
STATUS="$ZSH_THEME_GIT_PROMPT_UNMERGED$STATUS"
|
||||||
|
fi
|
||||||
|
if $(echo "$INDEX" | grep '^ D ' &> /dev/null); then
|
||||||
|
STATUS="$ZSH_THEME_GIT_PROMPT_DELETED$STATUS"
|
||||||
|
fi
|
||||||
|
if $(echo "$INDEX" | grep '^.M ' &> /dev/null); then
|
||||||
|
STATUS="$ZSH_THEME_GIT_PROMPT_MODIFIED$STATUS"
|
||||||
|
elif $(echo "$INDEX" | grep '^AM ' &> /dev/null); then
|
||||||
|
STATUS="$ZSH_THEME_GIT_PROMPT_MODIFIED$STATUS"
|
||||||
|
elif $(echo "$INDEX" | grep '^ T ' &> /dev/null); then
|
||||||
|
STATUS="$ZSH_THEME_GIT_PROMPT_MODIFIED$STATUS"
|
||||||
|
fi
|
||||||
|
# Staged
|
||||||
|
if $(echo "$INDEX" | grep '^D ' &> /dev/null); then
|
||||||
|
STATUS="$ZSH_THEME_GIT_PROMPT_STAGED_DELETED$STATUS"
|
||||||
|
fi
|
||||||
|
if $(echo "$INDEX" | grep '^R' &> /dev/null); then
|
||||||
|
STATUS="$ZSH_THEME_GIT_PROMPT_STAGED_RENAMED$STATUS"
|
||||||
|
fi
|
||||||
|
if $(echo "$INDEX" | grep '^M' &> /dev/null); then
|
||||||
|
STATUS="$ZSH_THEME_GIT_PROMPT_STAGED_MODIFIED$STATUS"
|
||||||
|
fi
|
||||||
|
if $(echo "$INDEX" | grep '^A' &> /dev/null); then
|
||||||
|
STATUS="$ZSH_THEME_GIT_PROMPT_STAGED_ADDED$STATUS"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if $(echo -n "$STATUS" | grep '.*' &> /dev/null); then
|
||||||
|
STATUS="$ZSH_THEME_GIT_STATUS_PREFIX$STATUS"
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo $STATUS
|
||||||
|
}
|
||||||
|
|
||||||
|
# get the name of the branch we are on (copied and modified from git.zsh)
|
||||||
|
function custom_git_prompt() {
|
||||||
|
ref=$(git symbolic-ref HEAD 2> /dev/null) || return
|
||||||
|
echo "$ZSH_THEME_GIT_PROMPT_PREFIX${ref#refs/heads/}$(parse_git_dirty)$(git_prompt_ahead)$(custom_git_prompt_status)$ZSH_THEME_GIT_PROMPT_SUFFIX"
|
||||||
|
}
|
||||||
|
|
||||||
|
# %B sets bold text
|
||||||
|
PROMPT='%B$PREFIX %2~ $(custom_git_prompt)%{$M%}%B»%b%{$RESET%} '
|
||||||
|
RPS1="${return_code}"
|
||||||
|
|
||||||
|
ZSH_THEME_GIT_PROMPT_PREFIX="%{$YB%}‹"
|
||||||
|
ZSH_THEME_GIT_PROMPT_SUFFIX="%{$YB%}›%{$RESET%} "
|
||||||
|
|
||||||
|
ZSH_THEME_GIT_PROMPT_DIRTY="%{$R%}*"
|
||||||
|
ZSH_THEME_GIT_PROMPT_CLEAN=""
|
||||||
|
|
||||||
|
ZSH_THEME_GIT_PROMPT_AHEAD="%{$BB%}➔"
|
||||||
|
|
||||||
|
ZSH_THEME_GIT_STATUS_PREFIX=" "
|
||||||
|
|
||||||
|
# Staged
|
||||||
|
ZSH_THEME_GIT_PROMPT_STAGED_ADDED="%{$G%}A"
|
||||||
|
ZSH_THEME_GIT_PROMPT_STAGED_MODIFIED="%{$G%}M"
|
||||||
|
ZSH_THEME_GIT_PROMPT_STAGED_RENAMED="%{$G%}R"
|
||||||
|
ZSH_THEME_GIT_PROMPT_STAGED_DELETED="%{$G%}D"
|
||||||
|
|
||||||
|
# Not-staged
|
||||||
|
ZSH_THEME_GIT_PROMPT_UNTRACKED="%{$R%}⁇"
|
||||||
|
ZSH_THEME_GIT_PROMPT_MODIFIED="%{$R%}M"
|
||||||
|
ZSH_THEME_GIT_PROMPT_DELETED="%{$R%}D"
|
||||||
|
ZSH_THEME_GIT_PROMPT_UNMERGED="%{$R%}UU"
|
18
themes/superjarin.zsh-theme
Normal file
18
themes/superjarin.zsh-theme
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
# Grab the current version of ruby in use (via RVM): [ruby-1.8.7]
|
||||||
|
JARIN_CURRENT_RUBY_="%{$fg[white]%}[%{$fg[red]%}\$(~/.rvm/bin/rvm-prompt i v)%{$fg[white]%}]%{$reset_color%}"
|
||||||
|
|
||||||
|
# Grab the current filepath, use shortcuts: ~/Desktop
|
||||||
|
# Append the current git branch, if in a git repository
|
||||||
|
JARIN_CURRENT_LOCA_="%{$fg_bold[cyan]%}%~\$(git_prompt_info)%{$reset_color%}"
|
||||||
|
ZSH_THEME_GIT_PROMPT_PREFIX="%{$fg[white]%} <%{$fg[magenta]%}"
|
||||||
|
ZSH_THEME_GIT_PROMPT_SUFFIX="%{$reset_color%}"
|
||||||
|
|
||||||
|
# Do nothing if the branch is clean (no changes).
|
||||||
|
ZSH_THEME_GIT_PROMPT_CLEAN="%{$reset_color%}>"
|
||||||
|
|
||||||
|
# Add a yellow ✗ if the branch is dirty
|
||||||
|
ZSH_THEME_GIT_PROMPT_DIRTY="%{$reset_color%}> %{$fg[yellow]%}✗"
|
||||||
|
|
||||||
|
# Put it all together!
|
||||||
|
PROMPT="$JARIN_CURRENT_RUBY_ $JARIN_CURRENT_LOCA_ "
|
||||||
|
|
9
themes/terminalparty.zsh-theme
Normal file
9
themes/terminalparty.zsh-theme
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
PROMPT='%{$fg[green]%} %% '
|
||||||
|
# RPS1='%{$fg[blue]%}%~%{$reset_color%} '
|
||||||
|
RPS1='%{$fg[white]%}%2~$(git_prompt_info) %{$fg_bold[blue]%}%m%{$reset_color%}'
|
||||||
|
|
||||||
|
ZSH_THEME_GIT_PROMPT_PREFIX=" (%{$fg[yellow]%}"
|
||||||
|
ZSH_THEME_GIT_PROMPT_SUFFIX=")%{$reset_color%}"
|
||||||
|
ZSH_THEME_GIT_PROMPT_CLEAN=""
|
||||||
|
ZSH_THEME_GIT_PROMPT_DIRTY="%{$fg[red]%} ⚡%{$fg[yellow]%}"
|
||||||
|
|
|
@ -1,29 +0,0 @@
|
||||||
function prompt_char {
|
|
||||||
git branch >/dev/null 2>/dev/null && echo '±' && return
|
|
||||||
hg root >/dev/null 2>/dev/null && echo '☿' && return
|
|
||||||
echo '○'
|
|
||||||
}
|
|
||||||
|
|
||||||
function virtualenv_info {
|
|
||||||
[ $VIRTUAL_ENV ] && echo '('`basename $VIRTUAL_ENV`') '
|
|
||||||
}
|
|
||||||
|
|
||||||
function hg_prompt_info {
|
|
||||||
hg prompt --angle-brackets "\
|
|
||||||
< on %{$fg[magenta]%}<branch>%{$reset_color%}>\
|
|
||||||
< at %{$fg[yellow]%}<tags|%{$reset_color%}, %{$fg[yellow]%}>%{$reset_color%}>\
|
|
||||||
%{$fg[green]%}<status|modified|unknown><update>%{$reset_color%}<
|
|
||||||
patches: <patches|join( → )|pre_applied(%{$fg[yellow]%})|post_applied(%{$reset_color%})|pre_unapplied(%{$fg_bold[black]%})|post_unapplied(%{$reset_color%})>>" 2>/dev/null
|
|
||||||
}
|
|
||||||
|
|
||||||
PROMPT='
|
|
||||||
%{$fg[magenta]%}%n%{$reset_color%} at %{$fg[yellow]%}%m%{$reset_color%} in %{$fg_bold[green]%}${PWD/#$HOME/~}%{$reset_color%}$(hg_prompt_info)$(git_prompt_info)
|
|
||||||
$(virtualenv_info)$(prompt_char) '
|
|
||||||
|
|
||||||
ZSH_THEME_GIT_PROMPT_PREFIX=" on %{$fg[magenta]%}"
|
|
||||||
ZSH_THEME_GIT_PROMPT_SUFFIX="%{$reset_color%}"
|
|
||||||
ZSH_THEME_GIT_PROMPT_DIRTY="%{$fg[green]%}!"
|
|
||||||
ZSH_THEME_GIT_PROMPT_UNTRACKED="%{$fg[green]%}?"
|
|
||||||
ZSH_THEME_GIT_PROMPT_CLEAN=""
|
|
||||||
|
|
||||||
. ~/bin/dotfiles/zsh/aliases
|
|
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:
|
107
themes/wedisagree.zsh-theme
Normal file
107
themes/wedisagree.zsh-theme
Normal file
|
@ -0,0 +1,107 @@
|
||||||
|
# On a mac with snow leopard, for nicer terminal colours:
|
||||||
|
|
||||||
|
# - Install SIMBL: http://www.culater.net/software/SIMBL/SIMBL.php
|
||||||
|
# - Download'Terminal-Colours': http://bwaht.net/code/TerminalColours.bundle.zip
|
||||||
|
# - Place that bundle in ~/Library/Application\ Support/SIMBL/Plugins (create that folder if it doesn't exist)
|
||||||
|
# - Open Terminal preferences. Go to Settings -> Text -> More
|
||||||
|
# - Change default colours to your liking.
|
||||||
|
#
|
||||||
|
# Here are the colours from Textmate's Monokai theme:
|
||||||
|
#
|
||||||
|
# Black: 0, 0, 0
|
||||||
|
# Red: 229, 34, 34
|
||||||
|
# Green: 166, 227, 45
|
||||||
|
# Yellow: 252, 149, 30
|
||||||
|
# Blue: 196, 141, 255
|
||||||
|
# Magenta: 250, 37, 115
|
||||||
|
# Cyan: 103, 217, 240
|
||||||
|
# White: 242, 242, 242
|
||||||
|
|
||||||
|
# Thanks to Steve Losh: http://stevelosh.com/blog/2009/03/candy-colored-terminal/
|
||||||
|
|
||||||
|
# The prompt
|
||||||
|
|
||||||
|
PROMPT='%{$fg[magenta]%}[%c] %{$reset_color%}'
|
||||||
|
|
||||||
|
# The right-hand prompt
|
||||||
|
|
||||||
|
RPROMPT='${time} %{$fg[magenta]%}$(git_prompt_info)%{$reset_color%}$(git_prompt_status)%{$reset_color%}'
|
||||||
|
|
||||||
|
# Add this at the start of RPROMPT to include rvm info showing ruby-version@gemset-name
|
||||||
|
# %{$fg[yellow]%}$(~/.rvm/bin/rvm-prompt)%{$reset_color%}
|
||||||
|
|
||||||
|
# local time, color coded by last return code
|
||||||
|
time_enabled="%(?.%{$fg[green]%}.%{$fg[red]%})%*%{$reset_color%}"
|
||||||
|
time_disabled="%{$fg[green]%}%*%{$reset_color%}"
|
||||||
|
time=$time_enabled
|
||||||
|
|
||||||
|
ZSH_THEME_GIT_PROMPT_PREFIX=" ☁ %{$fg[red]%}"
|
||||||
|
ZSH_THEME_GIT_PROMPT_SUFFIX="%{$reset_color%}"
|
||||||
|
ZSH_THEME_GIT_PROMPT_DIRTY="%{$fg[yellow]%} ☂" # Ⓓ
|
||||||
|
ZSH_THEME_GIT_PROMPT_UNTRACKED="%{$fg[cyan]%} ✭" # ⓣ
|
||||||
|
ZSH_THEME_GIT_PROMPT_CLEAN="%{$fg[green]%} ☀" # Ⓞ
|
||||||
|
|
||||||
|
ZSH_THEME_GIT_PROMPT_ADDED="%{$fg[cyan]%} ✚" # ⓐ ⑃
|
||||||
|
ZSH_THEME_GIT_PROMPT_MODIFIED="%{$fg[yellow]%} ⚡" # ⓜ ⑁
|
||||||
|
ZSH_THEME_GIT_PROMPT_DELETED="%{$fg[red]%} ✖" # ⓧ ⑂
|
||||||
|
ZSH_THEME_GIT_PROMPT_RENAMED="%{$fg[blue]%} ➜" # ⓡ ⑄
|
||||||
|
ZSH_THEME_GIT_PROMPT_UNMERGED="%{$fg[magenta]%} ♒" # ⓤ ⑊
|
||||||
|
|
||||||
|
# More symbols to choose from:
|
||||||
|
# ☀ ✹ ☄ ♆ ♀ ♁ ♐ ♇ ♈ ♉ ♚ ♛ ♜ ♝ ♞ ♟ ♠ ♣ ⚢ ⚲ ⚳ ⚴ ⚥ ⚤ ⚦ ⚒ ⚑ ⚐ ♺ ♻ ♼ ☰ ☱ ☲ ☳ ☴ ☵ ☶ ☷
|
||||||
|
# ✡ ✔ ✖ ✚ ✱ ✤ ✦ ❤ ➜ ➟ ➼ ✂ ✎ ✐ ⨀ ⨁ ⨂ ⨍ ⨎ ⨏ ⨷ ⩚ ⩛ ⩡ ⩱ ⩲ ⩵ ⩶ ⨠
|
||||||
|
# ⬅ ⬆ ⬇ ⬈ ⬉ ⬊ ⬋ ⬒ ⬓ ⬔ ⬕ ⬖ ⬗ ⬘ ⬙ ⬟ ⬤ 〒 ǀ ǁ ǂ ĭ Ť Ŧ
|
||||||
|
|
||||||
|
# Determine if we are using a gemset.
|
||||||
|
function rvm_gemset() {
|
||||||
|
GEMSET=`rvm gemset list | grep '=>' | cut -b4-`
|
||||||
|
if [[ -n $GEMSET ]]; then
|
||||||
|
echo "%{$fg[yellow]%}$GEMSET%{$reset_color%}|"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# Determine the time since last commit. If branch is clean,
|
||||||
|
# use a neutral color, otherwise colors will vary according to time.
|
||||||
|
function git_time_since_commit() {
|
||||||
|
if git rev-parse --git-dir > /dev/null 2>&1; then
|
||||||
|
# Only proceed if there is actually a commit.
|
||||||
|
if [[ $(git log 2>&1 > /dev/null | grep -c "^fatal: bad default revision") == 0 ]]; then
|
||||||
|
# Get the last commit.
|
||||||
|
last_commit=`git log --pretty=format:'%at' -1 2> /dev/null`
|
||||||
|
now=`date +%s`
|
||||||
|
seconds_since_last_commit=$((now-last_commit))
|
||||||
|
|
||||||
|
# Totals
|
||||||
|
MINUTES=$((seconds_since_last_commit / 60))
|
||||||
|
HOURS=$((seconds_since_last_commit/3600))
|
||||||
|
|
||||||
|
# Sub-hours and sub-minutes
|
||||||
|
DAYS=$((seconds_since_last_commit / 86400))
|
||||||
|
SUB_HOURS=$((HOURS % 24))
|
||||||
|
SUB_MINUTES=$((MINUTES % 60))
|
||||||
|
|
||||||
|
if [[ -n $(git status -s 2> /dev/null) ]]; then
|
||||||
|
if [ "$MINUTES" -gt 30 ]; then
|
||||||
|
COLOR="$ZSH_THEME_GIT_TIME_SINCE_COMMIT_LONG"
|
||||||
|
elif [ "$MINUTES" -gt 10 ]; then
|
||||||
|
COLOR="$ZSH_THEME_GIT_TIME_SHORT_COMMIT_MEDIUM"
|
||||||
|
else
|
||||||
|
COLOR="$ZSH_THEME_GIT_TIME_SINCE_COMMIT_SHORT"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
COLOR="$ZSH_THEME_GIT_TIME_SINCE_COMMIT_NEUTRAL"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$HOURS" -gt 24 ]; then
|
||||||
|
echo "($(rvm_gemset)$COLOR${DAYS}d${SUB_HOURS}h${SUB_MINUTES}m%{$reset_color%}|"
|
||||||
|
elif [ "$MINUTES" -gt 60 ]; then
|
||||||
|
echo "($(rvm_gemset)$COLOR${HOURS}h${SUB_MINUTES}m%{$reset_color%}|"
|
||||||
|
else
|
||||||
|
echo "($(rvm_gemset)$COLOR${MINUTES}m%{$reset_color%}|"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
COLOR="$ZSH_THEME_GIT_TIME_SINCE_COMMIT_NEUTRAL"
|
||||||
|
echo "($(rvm_gemset)$COLOR~|"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
}
|
|
@ -1,36 +1,36 @@
|
||||||
if [ -d ~/.oh-my-zsh ]
|
if [ -d ~/.oh-my-zsh ]
|
||||||
then
|
then
|
||||||
echo "You already have Oh My Zsh installed. You'll need to remove ~/.oh-my-zsh if you want to install"
|
echo "\033[0;33mYou already have Oh My Zsh installed.\033[0m You'll need to remove ~/.oh-my-zsh if you want to install"
|
||||||
exit
|
exit
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo "Cloning Oh My Zsh..."
|
echo "\033[0;34mCloning Oh My Zsh...\033[0m"
|
||||||
/usr/bin/env git clone https://github.com/robbyrussell/oh-my-zsh.git ~/.oh-my-zsh
|
/usr/bin/env git clone https://github.com/robbyrussell/oh-my-zsh.git ~/.oh-my-zsh
|
||||||
|
|
||||||
echo "Looking for an existing zsh config..."
|
echo "\033[0;34mLooking for an existing zsh config...\033[0m"
|
||||||
if [ -f ~/.zshrc ] || [ -h ~/.zshrc ]
|
if [ -f ~/.zshrc ] || [ -h ~/.zshrc ]
|
||||||
then
|
then
|
||||||
echo "Found ~/.zshrc. Backing up to ~/.zshrc.pre-oh-my-zsh";
|
echo "\033[0;33mFound ~/.zshrc.\033[0m \033[0;32]Backing up to ~/.zshrc.pre-oh-my-zsh\033[0m";
|
||||||
cp ~/.zshrc ~/.zshrc.pre-oh-my-zsh;
|
cp ~/.zshrc ~/.zshrc.pre-oh-my-zsh;
|
||||||
rm ~/.zshrc;
|
rm ~/.zshrc;
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo "Using the Oh My Zsh template file and adding it to ~/.zshrc"
|
echo "\033[0;34mUsing the Oh My Zsh template file and adding it to ~/.zshrc\033[0m"
|
||||||
cp ~/.oh-my-zsh/templates/zshrc.zsh-template ~/.zshrc
|
cp ~/.oh-my-zsh/templates/zshrc.zsh-template ~/.zshrc
|
||||||
|
|
||||||
echo "Copying your current PATH and adding it to the end of ~/.zshrc for you."
|
echo "\033[0;34mCopying your current PATH and adding it to the end of ~/.zshrc for you.\033[0m"
|
||||||
echo "export PATH=$PATH" >> ~/.zshrc
|
echo "export PATH=$PATH" >> ~/.zshrc
|
||||||
|
|
||||||
echo "Time to change your default shell to zsh!"
|
echo "\033[0;34mTime to change your default shell to zsh!\033[0m"
|
||||||
chsh -s `which zsh`
|
chsh -s `which zsh`
|
||||||
|
|
||||||
echo ' __ __ '
|
echo "\033[0;32m"' __ __ '"\033[0m"
|
||||||
echo ' ____ / /_ ____ ___ __ __ ____ _____/ /_ '
|
echo "\033[0;32m"' ____ / /_ ____ ___ __ __ ____ _____/ /_ '"\033[0m"
|
||||||
echo ' / __ \/ __ \ / __ `__ \/ / / / /_ / / ___/ __ \ '
|
echo "\033[0;32m"' / __ \/ __ \ / __ `__ \/ / / / /_ / / ___/ __ \ '"\033[0m"
|
||||||
echo '/ /_/ / / / / / / / / / / /_/ / / /_(__ ) / / / '
|
echo "\033[0;32m"'/ /_/ / / / / / / / / / / /_/ / / /_(__ ) / / / '"\033[0m"
|
||||||
echo '\____/_/ /_/ /_/ /_/ /_/\__, / /___/____/_/ /_/ '
|
echo "\033[0;32m"'\____/_/ /_/ /_/ /_/ /_/\__, / /___/____/_/ /_/ '"\033[0m"
|
||||||
echo ' /____/'
|
echo "\033[0;32m"' /____/ '"\033[0m"
|
||||||
|
|
||||||
echo "\n\n ....is now installed."
|
echo "\n\n \033[0;32m....is now installed.\033[0m"
|
||||||
/usr/bin/env zsh
|
/usr/bin/env zsh
|
||||||
source ~/.zshrc
|
source ~/.zshrc
|
||||||
|
|
|
@ -1,12 +1,12 @@
|
||||||
current_path=`pwd`
|
current_path=`pwd`
|
||||||
echo "Upgrading Oh My Zsh"
|
echo -e "\033[0;34mUpgrading Oh My Zsh\033[0m"
|
||||||
( cd $ZSH && git pull origin master )
|
( cd $ZSH && git pull origin master )
|
||||||
echo ' __ __ '
|
echo -e "\033[0;32m"' __ __ '"\033[0m"
|
||||||
echo ' ____ / /_ ____ ___ __ __ ____ _____/ /_ '
|
echo -e "\033[0;32m"' ____ / /_ ____ ___ __ __ ____ _____/ /_ '"\033[0m"
|
||||||
echo ' / __ \/ __ \ / __ `__ \/ / / / /_ / / ___/ __ \ '
|
echo -e "\033[0;32m"' / __ \/ __ \ / __ `__ \/ / / / /_ / / ___/ __ \ '"\033[0m"
|
||||||
echo '/ /_/ / / / / / / / / / / /_/ / / /_(__ ) / / / '
|
echo -e "\033[0;32m"'/ /_/ / / / / / / / / / / /_/ / / /_(__ ) / / / '"\033[0m"
|
||||||
echo '\____/_/ /_/ /_/ /_/ /_/\__, / /___/____/_/ /_/ '
|
echo -e "\033[0;32m"'\____/_/ /_/ /_/ /_/ /_/\__, / /___/____/_/ /_/ '"\033[0m"
|
||||||
echo ' /____/'
|
echo -e "\033[0;32m"' /____/ '"\033[0m"
|
||||||
echo "Hooray! Oh My Zsh has been updated and/or is at the current version. \nAny new updates will be reflected when you start your next terminal session."
|
echo -e "\033[0;34mHooray! Oh My Zsh has been updated and/or is at the current version.\033[0m"
|
||||||
echo "To keep up on the latest, be sure to follow Oh My Zsh on twitter: http://twitter.com/ohmyzsh"
|
echo -e "\033[0;34mTo keep up on the latest, be sure to follow Oh My Zsh on twitter: \033[1mhttp://twitter.com/ohmyzsh\033[0m"
|
||||||
cd $current_path
|
cd "$current_path"
|
||||||
|
|
Loading…
Reference in a new issue