Update zshrc from upstream

This commit is contained in:
Simon Bruder 2020-07-03 22:26:07 +02:00
parent 7e8d310e79
commit 0cd95ce10a
No known key found for this signature in database
GPG key ID: 6F03E0000CC5B62F

View file

@ -431,11 +431,22 @@ ZSH_NO_DEFAULT_LOCALE=${ZSH_NO_DEFAULT_LOCALE:-0}
typeset -ga ls_options typeset -ga ls_options
typeset -ga grep_options typeset -ga grep_options
# Colors on GNU ls(1)
if ls --color=auto / >/dev/null 2>&1; then if ls --color=auto / >/dev/null 2>&1; then
ls_options+=( --color=auto ) ls_options+=( --color=auto )
# Colors on FreeBSD and OSX ls(1)
elif ls -G / >/dev/null 2>&1; then elif ls -G / >/dev/null 2>&1; then
ls_options+=( -G ) ls_options+=( -G )
fi fi
# Natural sorting order on GNU ls(1)
# OSX and IllumOS have a -v option that is not natural sorting
if ls --version |& grep -q 'GNU' >/dev/null 2>&1 && ls -v / >/dev/null 2>&1; then
ls_options+=( -v )
fi
# Color on GNU and FreeBSD grep(1)
if grep --color=auto -q "a" <<< "a" >/dev/null 2>&1; then if grep --color=auto -q "a" <<< "a" >/dev/null 2>&1; then
grep_options+=( --color=auto ) grep_options+=( --color=auto )
fi fi
@ -659,7 +670,10 @@ fi
# completion system # completion system
COMPDUMPFILE=${COMPDUMPFILE:-${ZDOTDIR:-${HOME}}/.zcompdump} COMPDUMPFILE=${COMPDUMPFILE:-${ZDOTDIR:-${HOME}}/.zcompdump}
if zrcautoload compinit ; then if zrcautoload compinit ; then
compinit -d ${COMPDUMPFILE} || print 'Notice: no compinit available :(' typeset -a tmp
zstyle -a ':grml:completion:compinit' arguments tmp
compinit -d ${COMPDUMPFILE} "${tmp[@]}" || print 'Notice: no compinit available :('
unset tmp
else else
print 'Notice: no compinit available :(' print 'Notice: no compinit available :('
function compdef { } function compdef { }
@ -823,8 +837,18 @@ function grmlcomp () {
_ssh_hosts=() _ssh_hosts=()
_etc_hosts=() _etc_hosts=()
fi fi
local localname
if check_com hostname ; then
localname=$(hostname)
elif check_com hostnamectl ; then
localname=$(hostnamectl --static)
else
localname="$(uname -n)"
fi
hosts=( hosts=(
$(hostname) "${localname}"
"$_ssh_config_hosts[@]" "$_ssh_config_hosts[@]"
"$_ssh_hosts[@]" "$_ssh_hosts[@]"
"$_etc_hosts[@]" "$_etc_hosts[@]"
@ -881,7 +905,7 @@ zle -N end-of-somewhere beginning-or-end-of-somewhere
# add a command line to the shells history without executing it # add a command line to the shells history without executing it
function commit-to-history () { function commit-to-history () {
print -s ${(z)BUFFER} print -rs ${(z)BUFFER}
zle send-break zle send-break
} }
zle -N commit-to-history zle -N commit-to-history
@ -1208,7 +1232,7 @@ function help_zle_parse_keybindings () {
help_zle_keybindings['<Alt><arg>']="repeat next cmd/char <arg> times (<Alt>-<Alt>1<Alt>0a -> -10 times 'a')" help_zle_keybindings['<Alt><arg>']="repeat next cmd/char <arg> times (<Alt>-<Alt>1<Alt>0a -> -10 times 'a')"
help_zle_keybindings['<Alt>u']="make next word Uppercase" help_zle_keybindings['<Alt>u']="make next word Uppercase"
help_zle_keybindings['<Alt>l']="make next word lowercase" help_zle_keybindings['<Alt>l']="make next word lowercase"
help_zle_keybindings['<Ctrl>xd']="preview expansion under cursor" help_zle_keybindings['<Ctrl>xG']="preview expansion under cursor"
help_zle_keybindings['<Alt>q']="push current CL into background, freeing it. Restore on next CL" help_zle_keybindings['<Alt>q']="push current CL into background, freeing it. Restore on next CL"
help_zle_keybindings['<Alt>.']="insert (and interate through) last word from prev CLs" help_zle_keybindings['<Alt>.']="insert (and interate through) last word from prev CLs"
help_zle_keybindings['<Alt>,']="complete word from newer history (consecutive hits)" help_zle_keybindings['<Alt>,']="complete word from newer history (consecutive hits)"
@ -1842,7 +1866,7 @@ done
function batterydarwin () { function batterydarwin () {
GRML_BATTERY_LEVEL='' GRML_BATTERY_LEVEL=''
local -a table local -a table
table=( ${$(pmset -g ps)[(w)7,8]%%(\%|);} ) table=( ${$(pmset -g ps)[(w)8,9]%%(\%|);} )
if [[ -n $table[2] ]] ; then if [[ -n $table[2] ]] ; then
case $table[2] in case $table[2] in
charging) charging)
@ -2255,6 +2279,7 @@ grml_theme_add_token: Token `%s'\'' exists! Giving up!\n\n' $name
return 2 return 2
fi fi
if (( init )); then if (( init )); then
REPLY=''
$token $name $token $name
token=$REPLY token=$REPLY
fi fi
@ -2300,6 +2325,7 @@ function grml_prompt_addto () {
zstyle -s ":prompt:${grmltheme}:${lr}:items:$it" token new \ zstyle -s ":prompt:${grmltheme}:${lr}:items:$it" token new \
|| new=${grml_prompt_token_default[$it]} || new=${grml_prompt_token_default[$it]}
if (( ${+grml_prompt_token_function[$it]} )); then if (( ${+grml_prompt_token_function[$it]} )); then
REPLY=''
${grml_prompt_token_function[$it]} $it ${grml_prompt_token_function[$it]} $it
else else
case $it in case $it in
@ -2452,6 +2478,9 @@ else
function precmd () { (( ${+functions[vcs_info]} )) && vcs_info; } function precmd () { (( ${+functions[vcs_info]} )) && vcs_info; }
fi fi
# make sure to use right prompt only when not running a command
is41 && setopt transient_rprompt
# Terminal-title wizardry # Terminal-title wizardry
function ESC_print () { function ESC_print () {
@ -2493,8 +2522,11 @@ function grml_vcs_to_screen_title () {
} }
function grml_maintain_name () { function grml_maintain_name () {
# set hostname if not running on host with name 'grml' local localname
if [[ -n "$HOSTNAME" ]] && [[ "$HOSTNAME" != $(hostname) ]] ; then localname="$(uname -n)"
# set hostname if not running on local machine
if [[ -n "$HOSTNAME" ]] && [[ "$HOSTNAME" != "${localname}" ]] ; then
NAME="@$HOSTNAME" NAME="@$HOSTNAME"
fi fi
} }
@ -2511,7 +2543,7 @@ function grml_cmd_to_screen_title () {
function grml_control_xterm_title () { function grml_control_xterm_title () {
case $TERM in case $TERM in
(xterm*|rxvt*|alacritty) (xterm*|rxvt*|alacritty)
set_title "${(%):-"%n@%m:"}" "$1" set_title "${(%):-"%n@%m:"}" "$2"
;; ;;
esac esac
} }
@ -2691,22 +2723,24 @@ Enjoy your grml system with the zsh!$reset_color"
# debian stuff # debian stuff
if [[ -r /etc/debian_version ]] ; then if [[ -r /etc/debian_version ]] ; then
if [[ -z "$GRML_NO_APT_ALIASES" ]]; then if [[ -z "$GRML_NO_APT_ALIASES" ]]; then
#a3# Execute \kbd{apt-cache search}
alias acs='apt-cache search'
#a3# Execute \kbd{apt-cache show}
alias acsh='apt-cache show'
#a3# Execute \kbd{apt-cache policy} #a3# Execute \kbd{apt-cache policy}
alias acp='apt-cache policy' alias acp='apt-cache policy'
if check_com -c apt ; then if check_com -c apt ; then
#a3# Execute \kbd{apt search}
alias acs='apt search'
#a3# Execute \kbd{apt show}
alias acsh='apt show'
#a3# Execute \kbd{apt dist-upgrade} #a3# Execute \kbd{apt dist-upgrade}
salias adg="apt dist-upgrade" salias adg="apt dist-upgrade"
#a3# Execute \kbd{apt upgrade} #a3# Execute \kbd{apt upgrade}
salias ag="apt upgrade" salias ag="apt upgrade"
#a3# Execute \kbd{apt install} #a3# Execute \kbd{apt install}
salias agi="apt install" salias agi="apt install"
#a3# Execute \kbd{apt-get update} #a3# Execute \kbd{apt update}
salias au="apt update" salias au="apt update"
else else
alias acs='apt-cache search'
alias acsh='apt-cache show'
salias adg="apt-get dist-upgrade" salias adg="apt-get dist-upgrade"
salias ag="apt-get upgrade" salias ag="apt-get upgrade"
salias agi="apt-get install" salias agi="apt-get install"
@ -2786,6 +2820,17 @@ graphic chipset."
return 1 return 1
} }
fi fi
if check_com -c tmate && check_com -c qrencode ; then
function grml-remote-support() {
tmate -L grml-remote-support new -s grml-remote-support -d
tmate -L grml-remote-support wait tmate-ready
tmate -L grml-remote-support display -p '#{tmate_ssh}' | qrencode -t ANSI
echo "tmate session: $(tmate -L grml-remote-support display -p '#{tmate_ssh}')"
echo
echo "Scan this QR code and send it to your support team."
}
fi
} }
# now run the functions # now run the functions
@ -2910,9 +2955,6 @@ function sll () {
return ${RTN} return ${RTN}
} }
# TODO: Is it supported to use pager settings like this?
# PAGER='less -Mr' - If so, the use of $PAGER here needs fixing
# with respect to wordsplitting. (ie. ${=PAGER})
if check_com -c $PAGER ; then if check_com -c $PAGER ; then
#f3# View Debian's changelog of given package(s) #f3# View Debian's changelog of given package(s)
function dchange () { function dchange () {
@ -2920,13 +2962,28 @@ if check_com -c $PAGER ; then
[[ -z "$1" ]] && printf 'Usage: %s <package_name(s)>\n' "$0" && return 1 [[ -z "$1" ]] && printf 'Usage: %s <package_name(s)>\n' "$0" && return 1
local package local package
# `less` as $PAGER without e.g. `|lesspipe %s` inside $LESSOPEN can't properly
# read *.gz files, try to detect this to use vi instead iff available
local viewer
if [[ ${$(typeset -p PAGER)[2]} = -a ]] ; then
viewer=($PAGER) # support PAGER=(less -Mr) but leave array untouched
else
viewer=(${=PAGER}) # support PAGER='less -Mr'
fi
if [[ ${viewer[1]:t} = less ]] && [[ -z "${LESSOPEN}" ]] && check_com vi ; then
viewer='vi'
fi
for package in "$@" ; do for package in "$@" ; do
if [[ -r /usr/share/doc/${package}/changelog.Debian.gz ]] ; then if [[ -r /usr/share/doc/${package}/changelog.Debian.gz ]] ; then
$PAGER /usr/share/doc/${package}/changelog.Debian.gz $viewer /usr/share/doc/${package}/changelog.Debian.gz
elif [[ -r /usr/share/doc/${package}/changelog.gz ]] ; then elif [[ -r /usr/share/doc/${package}/changelog.gz ]] ; then
$PAGER /usr/share/doc/${package}/changelog.gz $viewer /usr/share/doc/${package}/changelog.gz
elif [[ -r /usr/share/doc/${package}/changelog ]] ; then elif [[ -r /usr/share/doc/${package}/changelog ]] ; then
$PAGER /usr/share/doc/${package}/changelog $viewer /usr/share/doc/${package}/changelog
else else
if check_com -c aptitude ; then if check_com -c aptitude ; then
echo "No changelog for package $package found, using aptitude to retrieve it." echo "No changelog for package $package found, using aptitude to retrieve it."
@ -3255,7 +3312,7 @@ fi
#f5# Backup \kbd{file_or_folder {\rm to} file_or_folder\_timestamp} #f5# Backup \kbd{file_or_folder {\rm to} file_or_folder\_timestamp}
function bk () { function bk () {
emulate -L zsh emulate -L zsh
local current_date=$(date -u "+%Y-%m-%dT%H:%M:%SZ") local current_date=$(date -u "+%Y%m%dT%H%M%SZ")
local clean keep move verbose result all to_bk local clean keep move verbose result all to_bk
setopt extended_glob setopt extended_glob
keep=1 keep=1
@ -3312,14 +3369,14 @@ return 0;;
elif (( clean > 0 )); then elif (( clean > 0 )); then
if (( $# > 0 )); then if (( $# > 0 )); then
for to_bk in "$@"; do for to_bk in "$@"; do
rm $verbose -rf "${to_bk%/}"_[0-9](#c4,)-(0[0-9]|1[0-2])-([0-2][0-9]|3[0-1])T([0-1][0-9]|2[0-3])(:[0-5][0-9])(#c2)Z rm $verbose -rf "${to_bk%/}"_[0-9](#c8)T([0-1][0-9]|2[0-3])([0-5][0-9])(#c2)Z
(( result += $? )) (( result += $? ))
done done
else else
if (( all > 0 )); then if (( all > 0 )); then
rm $verbose -rf *_[0-9](#c4,)-(0[0-9]|1[0-2])-([0-2][0-9]|3[0-1])T([0-1][0-9]|2[0-3])(:[0-5][0-9])(#c2)Z(D) rm $verbose -rf *_[0-9](#c8)T([0-1][0-9]|2[0-3])([0-5][0-9])(#c2)Z(D)
else else
rm $verbose -rf *_[0-9](#c4,)-(0[0-9]|1[0-2])-([0-2][0-9]|3[0-1])T([0-1][0-9]|2[0-3])(:[0-5][0-9])(#c2)Z rm $verbose -rf *_[0-9](#c8)T([0-1][0-9]|2[0-3])([0-5][0-9])(#c2)Z
fi fi
(( result += $? )) (( result += $? ))
fi fi
@ -3445,6 +3502,11 @@ function simple-extract () {
USES_STDIN=true USES_STDIN=true
USES_STDOUT=false USES_STDOUT=false
;; ;;
*tar.zst)
DECOMP_CMD="tar --zstd -xvf -"
USES_STDIN=true
USES_STDOUT=false
;;
*tar) *tar)
DECOMP_CMD="tar -xvf -" DECOMP_CMD="tar -xvf -"
USES_STDIN=true USES_STDIN=true
@ -3490,6 +3552,11 @@ function simple-extract () {
USES_STDIN=true USES_STDIN=true
USES_STDOUT=true USES_STDOUT=true
;; ;;
*zst)
DECOMP_CMD="zstd -d -c -"
USES_STDIN=true
USES_STDOUT=true
;;
*) *)
print "ERROR: '$ARCHIVE' has unrecognized archive type." >&2 print "ERROR: '$ARCHIVE' has unrecognized archive type." >&2
RC=$((RC+1)) RC=$((RC+1))
@ -3717,7 +3784,10 @@ if check_com -c hg ; then
fi # end of check whether we have the 'hg'-executable fi # end of check whether we have the 'hg'-executable
# grml-small cleanups # disable bracketed paste mode for dumb terminals
[[ "$TERM" == dumb ]] && unset zle_bracketed_paste
# grml-small cleanups and workarounds
# The following is used to remove zsh-config-items that do not work # The following is used to remove zsh-config-items that do not work
# in grml-small by default. # in grml-small by default.
@ -3727,6 +3797,8 @@ fi # end of check whether we have the 'hg'-executable
if (( GRMLSMALL_SPECIFIC > 0 )) && isgrmlsmall ; then if (( GRMLSMALL_SPECIFIC > 0 )) && isgrmlsmall ; then
# Clean up
unset "abk[V]" unset "abk[V]"
unalias 'V' &> /dev/null unalias 'V' &> /dev/null
unfunction vman &> /dev/null unfunction vman &> /dev/null
@ -3737,6 +3809,36 @@ if (( GRMLSMALL_SPECIFIC > 0 )) && isgrmlsmall ; then
unfunction manzsh &> /dev/null unfunction manzsh &> /dev/null
unfunction man2 &> /dev/null unfunction man2 &> /dev/null
# Workarounds
# See https://github.com/grml/grml/issues/56
if ! [[ -x ${commands[dig]} ]]; then
function dig_after_all () {
unfunction dig
unfunction _dig
autoload -Uz _dig
unfunction dig_after_all
}
function dig () {
if [[ -x ${commands[dig]} ]]; then
dig_after_all
command dig "$@"
return "$!"
fi
printf 'This installation does not include `dig'\'' for size reasons.\n'
printf 'Try `drill'\'' as a light weight alternative.\n'
return 0
}
function _dig () {
if [[ -x ${commands[dig]} ]]; then
dig_after_all
zle -M 'Found `dig'\'' installed. '
else
zle -M 'Try `drill'\'' instead of `dig'\''.'
fi
}
compdef _dig dig
fi
fi fi
zrclocal zrclocal