config/shell: improve completion & some functions
This commit is contained in:
parent
d29e0dd14f
commit
3b01d60544
|
@ -36,7 +36,7 @@ cl() {
|
||||||
cd() {
|
cd() {
|
||||||
if test -d "$DATA" && test "${1:--}" != "-" -a ! -d "$1" -a $# -eq 1
|
if test -d "$DATA" && test "${1:--}" != "-" -a ! -d "$1" -a $# -eq 1
|
||||||
then
|
then
|
||||||
dir=$(fd --no-ignore --glob "$1*" "$DATA" $MNT --maxdepth 2 --type d --max-results 1 2>/dev/null)
|
dir=$(fd --no-ignore --glob "$1*" "$DATA" "$MNT" --maxdepth 2 --type d --max-results 1 2>/dev/null)
|
||||||
test -n "$dir" && cd "$dir"
|
test -n "$dir" && cd "$dir"
|
||||||
else
|
else
|
||||||
builtin cd "$@" &&
|
builtin cd "$@" &&
|
||||||
|
@ -45,9 +45,10 @@ cd() {
|
||||||
# - column malaligns output with ANSI escape sequences (view with LESS="" less)
|
# - column malaligns output with ANSI escape sequences (view with LESS="" less)
|
||||||
# column --fillrows --output-width $(expr $COLUMNS + 20)
|
# column --fillrows --output-width $(expr $COLUMNS + 20)
|
||||||
# pr -4 -l1 -W $COLUMNS -S" "
|
# pr -4 -l1 -W $COLUMNS -S" "
|
||||||
|
# TODO test whether still needed with exa
|
||||||
command ls --sort=none --quote-name |
|
command ls --sort=none --quote-name |
|
||||||
head -12 |
|
head -12 |
|
||||||
xargs ls --sort=time --format=vertical --directory --literal --classify --color=always --width $COLUMNS |
|
COLUMNS=$(tput cols) xargs $(which exa >/dev/null 2>&1 && echo "exa --list-dirs --icons --reverse" || echo 'ls --format=vertical --literal --classify --directory') --sort=time --color=always |
|
||||||
head -3
|
head -3
|
||||||
code=$? && test $code -eq 141 || return $code
|
code=$? && test $code -eq 141 || return $code
|
||||||
fi
|
fi
|
||||||
|
|
|
@ -50,6 +50,7 @@ unalias rd 2>/dev/null
|
||||||
# System help {{{1
|
# System help {{{1
|
||||||
|
|
||||||
compdef help=man
|
compdef help=man
|
||||||
|
compdef h=help
|
||||||
alias info='info --vi-keys'
|
alias info='info --vi-keys'
|
||||||
|
|
||||||
sudos() {
|
sudos() {
|
||||||
|
@ -76,9 +77,9 @@ xtrace() {
|
||||||
set +x
|
set +x
|
||||||
}
|
}
|
||||||
|
|
||||||
# Shows source code for command, resolving nested aliases
|
# Shows source for given command, resolving nested aliases
|
||||||
wh() {
|
wh() {
|
||||||
local res=$(which "$@") || return $?
|
local res=$(which "$@" 2>/dev/null || type "$@") || return $?
|
||||||
# only works in zsh, not bash
|
# only works in zsh, not bash
|
||||||
if expr "$res" : "${@:$#}: aliased to" >/dev/null && ! expr "$res" : ".*builtin" >/dev/null
|
if expr "$res" : "${@:$#}: aliased to" >/dev/null && ! expr "$res" : ".*builtin" >/dev/null
|
||||||
then echo "$res" | bat --style=plain --language=sh &&
|
then echo "$res" | bat --style=plain --language=sh &&
|
||||||
|
@ -90,6 +91,12 @@ wh() {
|
||||||
}
|
}
|
||||||
compdef wh=which
|
compdef wh=which
|
||||||
|
|
||||||
|
# Find where a function was defined
|
||||||
|
def() {
|
||||||
|
autoload +X "$@"
|
||||||
|
type "$@"
|
||||||
|
}
|
||||||
|
|
||||||
pathadd() {
|
pathadd() {
|
||||||
local IFS=":"
|
local IFS=":"
|
||||||
local result="$@"
|
local result="$@"
|
||||||
|
@ -134,6 +141,7 @@ edit-shell() {
|
||||||
# Edit an executable in the PATH
|
# Edit an executable in the PATH
|
||||||
edit-bin() {
|
edit-bin() {
|
||||||
local toedit="$(resolvealias "$1")"
|
local toedit="$(resolvealias "$1")"
|
||||||
|
case "$toedit" in (*\ text*);; (*) toedit="$1";; esac
|
||||||
if f="$(which "$toedit" 2>/dev/null)" && test -f "$f"
|
if f="$(which "$toedit" 2>/dev/null)" && test -f "$f"
|
||||||
then edit "$f"
|
then edit "$f"
|
||||||
else edit-shell -f "$toedit"
|
else edit-shell -f "$toedit"
|
||||||
|
@ -358,7 +366,14 @@ alias grp='grpc --ignore-case'
|
||||||
# TODO remove some prefixes \([^ ]*/\)\?
|
# TODO remove some prefixes \([^ ]*/\)\?
|
||||||
grpr() { grp --color=always --recursive $(echo $DIRS_IGNORE | sed 's|-x |--exclude-dir |g') "$@" | less -FX; }
|
grpr() { grp --color=always --recursive $(echo $DIRS_IGNORE | sed 's|-x |--exclude-dir |g') "$@" | less -FX; }
|
||||||
# Grep in shell config files
|
# Grep in shell config files
|
||||||
grsh() { grpr --no-ignore-case "$@" $HOME/.{ba,z}sh* $HOME/.local/bin $CONFIG_SHELLS $CONFIG_ZSH; }
|
grsh() {
|
||||||
|
local search=$1
|
||||||
|
shift
|
||||||
|
case $1 in (-*|"");; (*) local filter=$1; shift;; esac
|
||||||
|
grpr --no-ignore-case "$search" "$@" $(test -z "$filter" &&
|
||||||
|
echo $HOME/.local/bin $CONFIG_SHELLS $CONFIG_ZSH $HOME/.{ba,z}sh* /{etc,usr/share}/{ba,z}sh* /etc/profile* ||
|
||||||
|
compgen -G "$XDG_CONFIG_HOME/$filter" -G "/usr/share/$filter" -G "/etc/$filter*" -G "$HOME/.$filter*")
|
||||||
|
}
|
||||||
|
|
||||||
# Recover stray swap files from neovim
|
# Recover stray swap files from neovim
|
||||||
vrec() {
|
vrec() {
|
||||||
|
@ -455,7 +470,9 @@ killJava() {
|
||||||
|
|
||||||
# Files {{{1
|
# Files {{{1
|
||||||
|
|
||||||
alias l="ls -l --almost-all --human-readable --group-directories-first --file-type"
|
which exa >/dev/null &&
|
||||||
|
alias l='exa --icons' &&
|
||||||
|
alias ll='l --long --extended --git --all'
|
||||||
|
|
||||||
if which fd >/dev/null
|
if which fd >/dev/null
|
||||||
then fn() { $(command -v fd || echo fdfind) --hidden --no-ignore-vcs --one-file-system "$@" | less -F; } # [F]ind [n]o ignore
|
then fn() { $(command -v fd || echo fdfind) --hidden --no-ignore-vcs --one-file-system "$@" | less -F; } # [F]ind [n]o ignore
|
||||||
|
@ -463,7 +480,7 @@ then fn() { $(command -v fd || echo fdfind) --hidden --no-ignore-vcs --one-file-
|
||||||
compdef ff=fd
|
compdef ff=fd
|
||||||
compdef fn=fd
|
compdef fn=fd
|
||||||
else
|
else
|
||||||
alias ff='find -not -path "*.sync*" -and -not \( -name daten -prune \)'
|
alias ff='find -not -path "*.sync*" -and -not \( -name daten -prune \) -iname'
|
||||||
alias f1='find -mindepth 1 -maxdepth 1'
|
alias f1='find -mindepth 1 -maxdepth 1'
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
@ -539,29 +556,31 @@ umoul() {
|
||||||
# get the last arg
|
# get the last arg
|
||||||
for arg; do true; done
|
for arg; do true; done
|
||||||
if test "$arg"
|
if test "$arg"
|
||||||
then mountpoint="$(test -d "$arg" && realpath "$arg" || echo "${MNT:-${XDG_RUNTIME_DIR}/mnt}/$arg")"
|
then mountpoints="$(test -d "$arg" && realpath "$arg" || echo "${MNT:-${XDG_RUNTIME_DIR}/mnt}/$arg")"
|
||||||
mountpoint "$mountpoint" 2>/dev/null || test -b "$mountpoint" ||
|
mountpoint "$mountpoints" 2>/dev/null || test -b "$mountpoints" ||
|
||||||
mountpoint="$(mount --show-labels | grep "$arg" | cut -d' ' -f3)"
|
mountpoints="$(mount --show-labels | grep "$arg" | cut -d' ' -f3)"
|
||||||
test "$mountpoint" || return 1
|
test "$mountpoints" || return 1
|
||||||
else mountpoint="$PWD"
|
else mountpoints="$PWD"
|
||||||
while test "$mountpoint" != "/"; do
|
while test "$mountpoints" != "/"; do
|
||||||
mountpoint "$mountpoint" >/dev/null && break
|
mountpoint "$mountpoints" >/dev/null && break
|
||||||
mountpoint="$(dirname "$mountpoint")"
|
mountpoints="$(dirname "$mountpoints")"
|
||||||
done
|
done
|
||||||
test "$(dirname "$mountpoint")" != "/" ||
|
test "$(dirname "$mountpoints")" != "/" ||
|
||||||
mountpoint="$(mount |
|
mountpoints="$(mount |
|
||||||
grep --invert-match -e " /[^m][^/]*\(/[^/]*\)\? " -e "/sys" -e "/run/user" -e "/run/docker" |
|
grep --invert-match -e " /[^m][^/]*\(/[^/]*\)\? " -e "/sys" -e "/run/user" -e "/run/docker" |
|
||||||
fzf --select-1 --exit-0 | awk '{print $3}')" ||
|
fzf --select-1 --exit-0 | awk '{print $3}')" ||
|
||||||
return $?
|
return $?
|
||||||
fi
|
fi
|
||||||
while true; do
|
while true; do
|
||||||
case "$PWD" in
|
case "$PWD" in
|
||||||
("$mountpoint"*) popd || builtin cd "$(dirname $mountpoint)";;
|
("$mountpoints"*) popd || builtin cd "$(dirname $mountpoints)";;
|
||||||
(*) break;;
|
(*) break;;
|
||||||
esac
|
esac
|
||||||
done
|
done
|
||||||
# pass on all args except last
|
# pass on all args except last
|
||||||
moul -u "${@:1:$(((# > 1) ? #-1 : 0))}" "$mountpoint"
|
for mountpoint in $mountpoints
|
||||||
|
do moul -u "${@:1:$(((# > 1) ? #-1 : 0))}" "$mountpoint"
|
||||||
|
done
|
||||||
}
|
}
|
||||||
|
|
||||||
resetdocker() {
|
resetdocker() {
|
||||||
|
|
|
@ -5,7 +5,6 @@ command -v notify-send >/dev/null &&
|
||||||
if which jrnl >/dev/null; then
|
if which jrnl >/dev/null; then
|
||||||
alias j='jrnl'
|
alias j='jrnl'
|
||||||
jn() { jrnl -to today "$@" | less +G; }
|
jn() { jrnl -to today "$@" | less +G; }
|
||||||
compdef jn=jrnl
|
|
||||||
alias jnc='jn -contains'
|
alias jnc='jn -contains'
|
||||||
alias jne='jrnl --edit'
|
alias jne='jrnl --edit'
|
||||||
# TODO jump to end
|
# TODO jump to end
|
||||||
|
|
|
@ -96,7 +96,7 @@ bindkey '^q' push-line-or-edit
|
||||||
|
|
||||||
export KEYTIMEOUT=1
|
export KEYTIMEOUT=1
|
||||||
|
|
||||||
# Obsolete: zsh-vim-mode plugin - Custom VIM bindings {{{
|
# Obsolete because of zsh-vim-mode plugin - Custom VIM bindings {{{
|
||||||
#bindkey -v
|
#bindkey -v
|
||||||
#autoload -Uz history-search-end
|
#autoload -Uz history-search-end
|
||||||
#
|
#
|
||||||
|
|
Loading…
Reference in New Issue