export EDITOR="vim"
export PAGER="less"
export LS_COLORS='di=34:ow=44;37:tw=44;37:st=44;37:ex=31:su=7;31:sg=7;31:ln=33:or=7;33:pi=32:do=32:bd=35:cd=35:so=32:*.bz2=36:*.dmg=36:*.gz=36:*.gpg=36:*.rar=36:*.tar=36:*.tbz2=36:*.tgz=36:*.xz=36:*.zip=36:*.orig=90:*~=90'
LISTMAX=32768
WORDCHARS="*?[];!#~"
local grep=""
local grep_color="auto"
local fgrep=""
local ls=""
local ls_color="auto"
local ls_on_cd="yes"
local ls_on_init="no"
bindkey -v
# history-incremental-search-backward is much more useful than
# _history-complete-*
bindkey "^R" history-incremental-search-backward
# Add a few other emacs bindings for convenience, as it's sometimes quicker to
# use those than to switch between modes.
bindkey "^A" beginning-of-line
bindkey "^E" end-of-line
bindkey "^D" delete-char-or-list
# backward-kill-word behaves more like vim, whereas vi-backward-kill-word is
# the vi behaviour.
bindkey "^W" backward-kill-word
setopt no_bg_nice
setopt no_nomatch
setopt extended_glob
setopt autocd
setopt auto_pushd
autoload -U compinit
compinit -C
# Ignore case on completion
zstyle ':completion:*' matcher-list 'm:{A-Z}={a-z} m:{a-z}={A-Z}'
if [ -n "$grep" -o -n "$grep_color" ]; then
if [ -z "$grep" ]; then
if which ggrep &>/dev/null; then
grep="ggrep"
else
grep="grep"
fi
fi
[ -n "$grep_color" -a "$grep_color[1]" != "-" ] && \
grep_color="--color=$grep_color"
alias grep="$grep $grep_color"
fi
if [ -n "$fgrep" -o -n "$grep_color" ]; then
if [ -z "$fgrep" ]; then
if which ggrep &>/dev/null; then
fgrep="ggrep -F"
else
fgrep="fgrep"
fi
fi
[ -n "$grep_color" -a "$grep_color[1]" != "-" ] && \
grep_color="--color=$grep_color"
alias fgrep="$fgrep $grep_color"
fi
if [ -n "$ls" -o -n "$ls_color" ]; then
if [ -z "$ls" ]; then
if which gls &>/dev/null; then
ls="gls"
else
ls="ls"
fi
fi
[ -n "$ls_color" -a "$ls_color[1]" != "-" ] && \
ls_color="--color=$ls_color"
alias ls="$ls $ls_color"
fi
if [ "$ls_on_cd" = "yes" ]; then
chpwd() {
ls
}
fi
if [ "$TERM_PROGRAM" = "Apple_Terminal" ]; then
update_terminal_cwd() {
printf '\e]7;%s\a' "file://$HOSTNAME${PWD// /%20}"
}
else
update_terminal_cwd() {
}
fi
set_prompt() {
PS1="%m:%c$@%B%(!.#.$)%b "
PS2="%B>%b "
RPS1="%(1j.%{$(print "\e[1;33m")%}%j%{$(print "\e[0m")%}.)"
RPS1+="%(?..%(1j. .)%{$(print "\e[1;31m")%}%?%{$(print "\e[0m")%})"
RPS2="%(1_.%{$(print "\e[1;30m")%}(%_%)%{$(print "\e[0m")%}.)"
}
set_prompt
_precmd() {
update_terminal_cwd
local branch_name
branch_name="$(git symbolic-ref HEAD 2>/dev/null)"
branch_name="${branch_name##refs/heads/}"
if [ -n "$branch_name" -a "$branch_name" != "master" ]; then
local branch
branch="%{$(print "\e[1;30m")%}("
branch+="%{$(print "\e[0;36m")%}$branch_name"
branch+="%{$(print "\e[1;30m")%})%{$(print "\e[0m")%}"
set_prompt "$branch"
else
set_prompt
fi
}
case $TERM in
aterm|Eterm|rxvt*|uxterm*|xterm*)
# Use set_title if you want to change the term title
set_title() {
# Without this, precmd would override it
precmd() {
_precmd
}
print -Pn "\e]0;$@\a"
}
unset_title() {
precmd() {
print -Pn "\e]0;%m:%c\a"
_precmd
}
}
unset_title
;;
*)
precmd() {
_precmd
}
;;
esac
extr() {
for i in $@; do
case $i in
*.7z)
7za x $i
;;
*.lha)
ofarc -x $i
;;
*.tar)
ofarc -x $i
;;
*.tbz | *.tbz2 | *.tar.bz2)
bzcat $i | ofarc -ttar -x -
;;
*.tgz | *.tar.gz)
ofarc -x $i
;;
*.txz | *.tar.xz)
xzcat $i | tar xfv -
;;
*.rar)
unrar x $i
;;
*.zip)
ofarc -x $i
;;
# These have to be the last for obvious reasons
*.bz2)
bunzip2 $i
;;
*.gz)
ofarc -x $i
;;
*.xz)
unxz $i
;;
*)
echo "$i: Unknown file type"
false
;;
esac
done
}
for ext in 7z lha tar tbz tbz2 tar.bz2 tgz tar.gz txz tar.xz rar zip bz2 gz xz
do
alias -s "$ext=extr"
done
[ "$EDITOR" = "vim" ] && alias vi=vim
which gpg2 &>/dev/null && alias gpg=gpg2
[ "$ls_on_init" = "yes" ] && ls
unset fgrep grep grep_color ls ls_color ls_on_cd ls_on_init