X-Git-Url: https://ruderich.org/simon/gitweb/?a=blobdiff_plain;f=zsh%2Frc;h=c1ee1d4aa2236ec8f3306fd230eb14b55336640f;hb=37a28c07c5752711e5d1f4686a2b3f17d62ce3b7;hp=04c99f2ed673da450287f4572a182579f5887b0d;hpb=7495cfbec6d778d14719fe6037385a3391a90d41;p=config%2Fdotfiles.git diff --git a/zsh/rc b/zsh/rc index 04c99f2..c1ee1d4 100644 --- a/zsh/rc +++ b/zsh/rc @@ -1,6 +1,6 @@ # Zsh configuration file. -# Copyright (C) 2011-2013 Simon Ruderich +# Copyright (C) 2011-2014 Simon Ruderich # # This file is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by @@ -16,9 +16,6 @@ # along with this file. If not, see . -source_debug '. ~/.zsh/rc' - - # Warn when creating global variables from inside a function. Needs to be set # before declaring a function. setopt warn_create_global @@ -38,12 +35,12 @@ zshrc_resolve_fg_to_resumed_job_name() { # Replace fg with the resumed job name. if [[ $1 == fg ]]; then - REPLY="${jobtexts[%+]}" + REPLY=${jobtexts[%+]} elif [[ $1 == fg\ * ]]; then - REPLY="${jobtexts[${1#fg }]}" + REPLY=${jobtexts[${1#fg }]} # Normal program, return as is. else - REPLY="$1" + REPLY=$1 fi } @@ -89,7 +86,7 @@ setopt longlistjobs # Use Vi(m) style key bindings. bindkey -v -# Use jk to exit insert mode (jj is too slow). +# Use jk to exit insert mode (jj is too slow to type). bindkey 'jk' vi-cmd-mode # I don't need the arrow keys, I use ^N and ^P for this (see below). @@ -145,8 +142,8 @@ autoload -Uz zmv # HISTORY SETTINGS # Use history and store it in ~/.zsh/history. -HISTSIZE=50000 -SAVEHIST=50000 +HISTSIZE=1000000 +SAVEHIST=1000000 HISTFILE=~/.zsh/history # Append to the history file instead of overwriting it and do it immediately # when a command is executed. @@ -187,12 +184,12 @@ bindkey -a '^N' history-beginning-search-forward # Enable incremental search which is especially useful when the string is an # argument and not the command. -bindkey '^R' history-incremental-search-backward +bindkey '^R' history-incremental-pattern-search-backward # Also enable my usual use of Ctrl-P/Ctrl-N to get the previous/next matching # history entry. if [[ $ZSH_VERSION == (4.<4->*|<5->*) ]]; then - bindkey -M isearch '^P' history-incremental-search-backward - bindkey -M isearch '^N' history-incremental-search-forward + bindkey -M isearch '^P' history-incremental-pattern-search-backward + bindkey -M isearch '^N' history-incremental-pattern-search-forward fi # Automatically push cd-ed directories on the directory stack. @@ -214,7 +211,8 @@ autoload -Uz colors; colors zmodload zsh/datetime # Some shortcuts for colors. The %{...%} tells zsh that the data in between -# doesn't need any space, necessary for correct prompt drawing. +# doesn't need any space, necessary for correct prompt drawing. Use %F{color} +# in more recent zsh versions (here compatibility is important). local red="%{${fg[red]}%}" local blue="%{${fg[blue]}%}" local green="%{${fg[green]}%}" @@ -279,7 +277,7 @@ if [[ $ZSH_VERSION == (4.3.<9->*|4.<4->*|<5->*) || +vi-pre-get-data() { # Only Git and Mercurial support and need caching. Abort if any other # VCS is used. - [[ "$vcs" != git && "$vcs" != hg ]] && return + [[ $vcs != git && $vcs != hg ]] && return # If the shell just started up or we changed directories (or for other # custom reasons) we must run vcs_info. @@ -292,7 +290,7 @@ if [[ $ZSH_VERSION == (4.3.<9->*|4.<4->*|<5->*) || ret=1 # If a git/hg command was run then run vcs_info as the status might # need to be updated. - case "$(fc -ln $(($HISTCMD-1)))" in + case $(fc -ln $(($HISTCMD-1))) in git* | g\ *) ret=0 ;; @@ -339,12 +337,12 @@ zshrc_longrun_data=() # Display runtime in seconds for long running programs (> 60 seconds) and send # a bell to notify me. zshrc_longrun_preexec() { - local program="$3" + local program=$3 # Handle fg. local REPLY - zshrc_resolve_fg_to_resumed_job_name "$program" - program="$REPLY" + zshrc_resolve_fg_to_resumed_job_name $program + program=$REPLY # Don't track the time for certain (possible) long running processes which # need no automatic notification. @@ -357,7 +355,7 @@ zshrc_longrun_preexec() { esac done - zshrc_longrun_data=("$program" $EPOCHSECONDS) + zshrc_longrun_data=($program $EPOCHSECONDS) } zshrc_longrun_precmd() { # No previous timestamp available or disabled for this command, ignore. @@ -413,10 +411,10 @@ zshrc_prompt_precmd() { local directory="${yellow}%WIDTH<..<%~%<<${default}" # Minimal information about the VCS, only displayed if there are # unstaged/staged changes. - local vcs_staged="${vcs_info_msg_1_}" + local vcs_staged=${vcs_info_msg_1_} # Information about the VCS in this directory. - local vcs="${vcs_info_msg_0_}" + local vcs=${vcs_info_msg_0_} # Current time (seconds since epoch) in Hex in bright blue. local seconds="${blue}%B0x$(([##16] EPOCHSECONDS))%b${default}" @@ -442,7 +440,7 @@ zshrc_prompt_precmd() { # Combine them to create the prompt. - local top_left="${vcs_staged}" + local top_left=${vcs_staged} local top_right="${vcs}(${seconds})" local width_top_prefix=${#${(S%%)top_prefix//$~zero/}} @@ -511,8 +509,8 @@ if [[ $TERM == screen* || $TERM == xterm* || $TERM == rxvt* ]]; then # Handle fg. local REPLY - zshrc_resolve_fg_to_resumed_job_name "$program_name" - program_name="$REPLY" + zshrc_resolve_fg_to_resumed_job_name $program_name + program_name=$REPLY # Remove all arguments from the program name. program_name=${program_name%% *} @@ -566,7 +564,7 @@ if [[ $TERM == screen* || $TERM == xterm* || $TERM == rxvt* ]]; then fi # Set the window name to the currently running program. - zshrc_window_title "$program_name" + zshrc_window_title $program_name # Tell precmd() to reset the window name when the program stops. zshrc_window_reset=yes @@ -780,7 +778,7 @@ zle -C complete-files complete-word _generic zstyle ':completion:complete-files:*' completer _files bindkey '^F' complete-files -# Completion for my wrapper scripts +# Completion for my wrapper scripts. compdef slocate=locate compdef srsync=rsync compdef srsync-incremental=rsync @@ -801,7 +799,7 @@ compdef svalgrind=valgrind TRAPINT() { # Don't store this line in history if histignorespace is enabled and the # line starts with a space. - if [[ -o histignorespace && ${BUFFER[1]} = " " ]]; then + if [[ -o histignorespace && ${BUFFER[1]} = ' ' ]]; then return $1 fi @@ -868,35 +866,29 @@ fi command tig --max-count=200 --branches --remotes --tags "$@" } -# Pipe output through less. -(( $+commands[tree] )) && tree() { - command tree -C "$@" | less -} - -# Choose the "best" PDF viewer available: xpdf, then zathura (in the past -# zathura was preferred, but recent versions are completely broken: still no -# working search and no page-wise scrolling anymore). Also setup completion -# for `pdf`. -if (( $+commands[xpdf] )); then +# Choose the "best" PDF viewer available. Also setup completion for `pdf`. +if (( $+commands[katarakt] )); then + pdf() { + command katarakt "$@" 2>/dev/null & + disown %command + } + # No completion for katarakt yet. + compdef pdf=xpdf +elif (( $+commands[xpdf] )); then pdf() { command xpdf "$@" 2>/dev/null & disown %command } - compdef _xpdf pdf + compdef pdf=xpdf elif (( $+commands[zathura] )); then pdf() { command zathura "$@" 2>/dev/null & disown %command } # No completion for zathura yet. - compdef _xpdf pdf + compdef pdf=xpdf fi -# Better viewer for info pages .. just pipe everything into less. -info() { - command info "$@" 2>/dev/null | less -} - # OS SPECIFIC SETTINGS @@ -934,7 +926,8 @@ fi # If not already in screen or tmux, reattach to a running session or create a # new one. This also starts screen/tmux on a remote server when connecting # through ssh. -if [[ $TERM != dumb && $TERM != linux && -z $STY && -z $TMUX ]]; then +if [[ $TERM != dumb && $TERM != dialup && $TERM != linux + && -z $STY && -z $TMUX ]]; then # Get running detached sessions. if [[ $zshrc_use_multiplexer = screen ]]; then session=$(screen -list | grep 'Detached' | awk '{ print $1; exit }') @@ -988,7 +981,7 @@ if [[ $LD_PRELOAD != *libcoloredstderr.so* ]]; then # process when starting GNU screen/tmux (see above). else exec 2>>(while read -r -k -u 0 line; do - printf '\e[91m%s\e[0m' "$line" + printf '\e[91m%s\e[0m' $line print -n $'\0' done &) fi @@ -1036,7 +1029,7 @@ zshrc_restart_precmd() { fi local startup - strftime -s startup '%Y-%m-%d %H:%M:%S' "$zshrc_startup_time" + strftime -s startup '%Y-%m-%d %H:%M:%S' $zshrc_startup_time echo -n "${fg[magenta]}" echo -n "~/.zshrc modified since startup ($startup) ... " @@ -1055,12 +1048,12 @@ zshrc_restart_precmd() { fi # Try to start a new interactive shell. If it fails, something is wrong. - # Don't kill our current session by execing it. + # Don't kill our current session by execing it, abort instead. zsh -i -c 'exit 42' if [[ $? -ne 42 ]]; then - echo -n "${fg_bold[red]}" + echo -n ${fg_bold[red]} echo 'failed to start new zsh!' - echo -n "${fg_bold[default]}" + echo -n ${fg_bold[default]} return fi @@ -1071,7 +1064,4 @@ zshrc_restart_precmd() { } precmd_functions+=(zshrc_restart_precmd) - -source_debug '. ~/.zsh/rc (done)' - # vim: ft=zsh