X-Git-Url: http://www.git.stargrave.org/?a=blobdiff_plain;f=zsh%2F.zshrc;h=048fee325f080804863f9409a343d93c463fe33e;hb=f51006942c42932c1db15534f8d3f9b47a69704a;hp=0756acccf4c46ebd56138eff6ad1fa52018fcd75;hpb=1870931657239216f097193281d52014d34fa903;p=dotfiles.git diff --git a/zsh/.zshrc b/zsh/.zshrc index 0756acc..048fee3 100644 --- a/zsh/.zshrc +++ b/zsh/.zshrc @@ -1,8 +1,6 @@ # vim: foldmethod=marker:foldlevel=0 # Basic options {{{ -setopt APPEND_HISTORY SHARE_HISTORY INC_APPEND_HISTORY HIST_IGNORE_ALL_DUPS -setopt HIST_IGNORE_SPACE setopt INTERACTIVE_COMMENTS setopt GLOB_STAR_SHORT GLOB_DOTS EXTENDED_GLOB setopt NO_NOMATCH @@ -12,6 +10,12 @@ setopt RM_STAR_SILENT export LISTMAX=9999 # }}} +# History options {{{ +setopt APPEND_HISTORY SHARE_HISTORY INC_APPEND_HISTORY HIST_IGNORE_ALL_DUPS +setopt HIST_IGNORE_SPACE +HISTORY_IGNORE="(yt* *|t *|t|mmfileget *|arr|rss)" +# }}} + # Vi mode {{{ bindkey -v export KEYTIMEOUT=1 @@ -34,9 +38,14 @@ zle -N history-beginning-search-backward-end history-search-end zle -N history-beginning-search-forward-end history-search-end bindkey "^[[A" history-beginning-search-backward-end bindkey "^[[B" history-beginning-search-forward-end -bindkey "^R" history-incremental-pattern-search-backward -HISTORY_IGNORE="(yt* *|t *|t|mmfileget *)" +beginning-history-incremental-pattern-search-backward() { + zle history-incremental-pattern-search-backward $(echo $BUFFER | sed "s/ /*/g") +} +zle -N beginning-history-incremental-pattern-search-backward +bindkey "^[[1;2A" beginning-history-incremental-pattern-search-backward +bindkey -M isearch "^[[A" history-incremental-pattern-search-backward +bindkey -M isearch "^[[B" history-incremental-pattern-search-forward # }}} # Prompt {{{ @@ -47,7 +56,7 @@ function zle-line-init zle-keymap-select { prompt+="%U${timer_show}%u|" prompt+="%B%?%b" prompt+="${mode_vi}" - prompt+="%F{magenta}%#%f " + prompt+="%B%F{magenta}%#%f%b " PS1="$prompt" zle reset-prompt } @@ -71,8 +80,8 @@ alias vi="vim" alias more="less" alias m="less " alias -g M="| less" +alias -g W="| wc -l" alias mc="mc --nomouse" -bindkey -s "OS" " popd\n" # F4 f() { # find . -name "*$1*" -print @@ -85,22 +94,38 @@ ssht() { alias sshnm="ssh -S none" # }}} +# Faster movement {{{ +cddotdot() { + cd .. + pwd + zle reset-prompt +} +zle -N cddotdot +bindkey "OQ" cddotdot # F2 + +pushdquiet() { + popd + zle reset-prompt +} +zle -N pushdquiet +bindkey "OS" pushdquiet # F4 +# }}} + # Git {{{ alias Ga="git add" alias Gb="git branch" alias Gc="git checkout" alias Gd="git diff" -alias Gs="git show" +alias Gdc="git diff --cached" +alias Gs="git show --show-signature" alias Gm="git diff --name-only --diff-filter=M" alias Gam="git commit --amend" -alias -g W="| wc -l" git_common="--oneline --abbrev-commit" alias Gl="git log $git_common --graph --decorate=short" alias Gr="git --no-pager log $git_common -n 20 | perl -ne 'print \"@~\$n \$_\"; \$n++'" alias Grr="git --no-pager log $git_common --graph -n 1024 | vi -c 'setlocal filetype=gitrebase buftype=nofile noswapfile' -" -bindkey -s "OQ" " git status\n" # F2 bindkey -s "OR" " git status --short\n" # F3 # }}}