X-Git-Url: http://www.git.stargrave.org/?p=dotfiles.git;a=blobdiff_plain;f=zsh%2F.zshrc;h=7e8cc22ec3218606c277d494fff631cce7ac0aec;hp=778759a9695789328f15cd2cebb14178e412dae2;hb=38c1b0544d9528bc787b5c258b9c0fdacdcd86da;hpb=9f3136fba1e022b17a1293e0fc9bead012d49c80 diff --git a/zsh/.zshrc b/zsh/.zshrc index 778759a..7e8cc22 100644 --- a/zsh/.zshrc +++ b/zsh/.zshrc @@ -1,11 +1,11 @@ # vim: foldmethod=marker:foldlevel=0 # Basic options {{{ -setopt INTERACTIVE_COMMENTS setopt GLOB_STAR_SHORT GLOB_DOTS EXTENDED_GLOB setopt NO_NOMATCH setopt AUTO_PUSHD PUSHD_IGNORE_DUPS setopt PIPE_FAIL +setopt MULTIBYTE setopt RM_STAR_SILENT export LISTMAX=9999 @@ -23,8 +23,8 @@ export KEYTIMEOUT=1 # }}} # Home/end {{{ -bindkey "^[[1~" beginning-of-line -bindkey "^[[4~" end-of-line +bindkey "^[[1~" beginning-of-line # Home +bindkey "^[[4~" end-of-line # End # }}} # Command-line editing {{{ @@ -51,13 +51,13 @@ bindkey -M isearch "^[[B" history-incremental-pattern-search-forward # Prompt {{{ function zle-line-init zle-keymap-select { - mode_vi=${${KEYMAP/vicmd/+}/(main|viins)/-} - [[ $timer ]] && timer_show=$(( $SECONDS - $timer )) - prompt="%2~|" - prompt+="%U${timer_show}%u|" + local state="%#" timer_val="?" + [[ ${KEYMAP} == vicmd ]] && state="+" + [[ $timer ]] && timer_val=$(( $SECONDS - $timer )) + prompt="%2~ " + prompt+="%U${timer_val}%u|" prompt+="%B%?%b" - prompt+="${mode_vi}" - prompt+="%B%F{magenta}%#%f%b " + prompt+="%B%F{magenta}${state}%f%b " PS1=$prompt zle reset-prompt } @@ -75,25 +75,29 @@ precmd() { # Aliases {{{ alias l="ls -AF " -alias ll="ls -AFl " -alias ssh="TERM=xterm ssh" +alias ll="ls -D %Y-%m-%d -AFl " alias vi="vim" -alias more="less" alias m="less " alias -g M="| less" alias -g W="| wc -l | sed 's/ //g'" +alias -g T="| tai64nlocal" alias mc="mc --nomouse" -alias sent="mutt -f =sent-\`date '+%y-%m'\`" f() { - # find . -name "*$1*" -print - print -C 1 **$1* + bfs . -name "*$1*" -print } +alias ssh="TERM=xterm ssh" +alias sshnm="ssh -S none" ssht() { - ssh -C -t $1 tmux attach -t0 + local t="-t 0" + TERM=xterm ssh -C -t $1 "tmux has-session $t && tmux attach-session $t || tmux new-session $t" } -alias sshnm="ssh -S none" + +autoload -U zsh-mime-setup ; zsh-mime-setup +alias -s html=lynx + +autoload -U zmv # }}} # Faster movement {{{ @@ -105,12 +109,12 @@ cddotdot() { zle -N cddotdot bindkey "OQ" cddotdot # F2 -pushdquiet() { +popdquiet() { popd zle reset-prompt } -zle -N pushdquiet -bindkey "OS" pushdquiet # F4 +zle -N popdquiet +bindkey "OS" popdquiet # F4 # }}} # Git {{{ @@ -120,13 +124,10 @@ alias Gc="git checkout" alias Gd="git diff" alias Gdc="git diff --cached" alias Gs="git show --show-signature" -alias Gm="git diff --name-only --diff-filter=M" +alias Gm="git diff --name-only --diff-filter=M --relative" alias Gam="git commit --amend" - alias Gl="git log --oneline --graph --decorate=short" alias Gld="git log --format=format:'%ai %Cgreen%h%Creset %s'" -alias Gr="git --no-pager log --oneline -n 20 | perl -ne 'print \"@~\$n \$_\"; \$n++'" -alias Grr="git --no-pager log --oneline --graph -n 1024 | vi -c 'setlocal filetype=gitrebase buftype=nofile noswapfile' -" bindkey -s "OR" " git status --short\n" # F3 # }}} @@ -141,26 +142,15 @@ GREP_ARGS=( --exclude-dir=.git --exclude-dir=.tags ) -LESS_COLOURED=(less --RAW-CONTROL-CHARS) g() { - grep $GREP_ARGS $@ | $LESS_COLOURED -} -GS() { - grep $GREP_ARGS $@ | sort --numeric-sort | $LESS_COLOURED + grep $GREP_ARGS $@ | less } alias -g G="| grep --colour=always" alias gg="git grep " # }}} # GPG agent {{{ -GPG_TTY=$(tty) -export GPG_TTY -# }}} - -# Virtualenv {{{ -venv() { - . /usr/local/bin/virtualenvwrapper.sh -} +export GPG_TTY=$(tty) # }}} # Mail {{{ @@ -168,16 +158,36 @@ mailpath=( ~/mail/mbox"?Neue Nachrichten in =mbox" ~/mail/arbeit"?Neue Nachrichten in =arbeit" ) -alias arr="mutt -f \=arbeit -e 'source ~/.mutt/accounts/stcnet.ru'" +alias arr="mutt -f =arbeit -e 'source ~/.mutt/accounts/stcnet.ru'" +alias sent="mutt -f =sent-\`date '+%y-%m'\`" bindkey -s "OP" " inc\n" # F1 # }}} # Completion {{{ +zstyle ":completion:*" list-colors "" + zstyle ":completion:*:functions" ignored-patterns "_*" -zstyle ":completion:*" matcher-list "" 'm:{a-z\-}={A-Z\_}' 'r:|?=** m:{a-z\-}={A-Z\_}' +zstyle ":completion:*:manuals" separate-sections true + +zstyle ":completion:*" group-name "" +zstyle ":completion:*:messages" format "%d" +zstyle ":completion:*:warnings" format "%F{red}no matches: %d%f" +zstyle ":completion:*:*:*:*:descriptions" format "%B... %d%b" +zstyle ":completion:*:files:*:*:descriptions" format "" + +zstyle ":completion:*" file-patterns "%p:globbed" "*" +zstyle ":completion:*" matcher-list "" "m:{a-z-}={A-Z_}" "r:|?=** m:{a-z-}={A-Z_}" +zstyle ":completion:*:man:*:*:*" matcher-list "" "m:{a-zA-Z}={A-Za-z} l:|=* r:|=*" +zstyle ":completion:*" completer _mycomp _mycomp_man:man _parameters _ignored + _mycomp () { - [[ ${words[1]} != man ]] || { _man && return 0 } - [[ $CURRENT -eq 1 ]] && _command_names || _files && return 0 + [[ $CURRENT -eq 1 ]] && curcontext="${curcontext%:*:*}:-command-:" \ + _command_names && return + [[ $IPREFIX =~ ~.* ]] && _tilde && return + local has_files + curcontext=:files:${curcontext#:*:} _files && has_files=1 + [[ $has_files ]] && return + # MAGIC_EQUAL_SUBST {{{ [[ $PREFIX = *\=* ]] || return 1 compstate[parameter]=${PREFIX%%\=*} @@ -185,9 +195,15 @@ _mycomp () { _value # }}} } -zstyle ":completion:*" completer _mycomp _parameters + +_mycomp_man () { + [[ ${words[1]} == man ]] && curcontext=:man:${curcontext#:*:} \ + _dispatch "" man man "" -default- && _value && return + [[ ${words[1]} == info ]] && curcontext=:info:${curcontext#:*:} \ + _dispatch "" info info "" -default- && return +} + autoload -U compinit ; compinit -d /tmp/.zcompdump -zstyle ":completion:*:default" list-colors "" autoload -U complist # }}} @@ -213,11 +229,13 @@ ZSH_AUTOSUGGEST_HIGHLIGHT_STYLE="fg=cyan" # }}} # fzf {{{ -export FZF_DEFAULT_OPTS="--color=16 --info=inline" cf() { - local dir=$(find ${1:-.} -mindepth 1 -path "*/\.git" -prune -o -type d -print | - fzf --height 40% --reverse --preview="tree -CN {}") - [[ -z $dir ]] || cd $dir + local dir=$(bfs -L ${1:-.} -mindepth 1 \ + -path "*/\.git" -prune -o \ + -path "*/\.redo" -prune -o \ + -type d -print 2>/dev/null | + fzf --height 40% --reverse --preview="tree -CN {}") + [[ -z $dir ]] || { print -s cd $dir ; cd $dir } } # }}} @@ -228,7 +246,12 @@ while read w ; do done < ~/.zhashd # }}} +# Virtualenv {{{ +venv() { + . /usr/local/bin/virtualenvwrapper.sh +} +# }}} + # autoenv {{{ -export AUTOENV_AUTH_FILE=~/.zautoenv-auth . ~/work/zsh-autoenv/autoenv.zsh # }}}