X-Git-Url: https://git.madduck.net/etc/ssh.git/blobdiff_plain/5dae703a994751dddb49d7d7396999cb2fed9088..6b87f90ed79ac94c90e92e6cb01b0fbd0bf9e577:/.zsh/zshrc/parts.d/50-ssh diff --git a/.zsh/zshrc/parts.d/50-ssh b/.zsh/zshrc/parts.d/50-ssh index 335f5f3..8ece86b 100644 --- a/.zsh/zshrc/parts.d/50-ssh +++ b/.zsh/zshrc/parts.d/50-ssh @@ -21,18 +21,29 @@ _ssh_proxy() { cmd="$1"; shift sshopts="${*%%--*}"; sshopts="${sshopts%% }" cmdopts="${*#$sshopts}"; cmdopts="${cmdopts#*-- }" - ssh $sshopts -t $cmd $cmdopts + eval ssh $sshopts -t $cmd $cmdopts } -alias rrsh='_ssh_proxy "su -"' +# need functions instead of aliases for completion +rrsh() { _ssh_proxy "su -" "$@" } compdef rrsh=ssh -alias ttsh='_ssh_proxy "tmux last"' +ttsh() { _ssh_proxy "tmux last" "$@" } compdef ttsh=ssh -alias rtsh='_ssh_proxy "tmux new su -"' +rtsh() { _ssh_proxy "tmux new su -" "$@" } compdef rtsh=ssh -alias kssh='rm -vf -- $VARDIR/ssh/ssh_control_*(=as-60Y1omN)' +local SOCKDIR=$VARDIR/ssh +kssh() { + local SOCKDIR=$SOCKDIR + if [[ -z "$1" ]]; then + rm -vf -- $SOCKDIR/ssh_control_*(=as-60Y1omN) + else + rm "$@" + fi +} +compdef "_files -W $SOCKDIR" kssh +unset SOCKDIR # vim:ft=zsh