X-Git-Url: https://git.madduck.net/etc/ssh.git/blobdiff_plain/8c5011b79b3fe6ed34794468bf0dd7b158964a10..6b87f90ed79ac94c90e92e6cb01b0fbd0bf9e577:/.zsh/zshrc/parts.d/50-ssh?ds=sidebyside

diff --git a/.zsh/zshrc/parts.d/50-ssh b/.zsh/zshrc/parts.d/50-ssh
index 647dd9e..8ece86b 100644
--- a/.zsh/zshrc/parts.d/50-ssh
+++ b/.zsh/zshrc/parts.d/50-ssh
@@ -16,4 +16,34 @@ if [ -r $HOME/.ssh/known_hosts ]; then
   unset _myhosts
 fi
 
+_ssh_proxy() {
+  local cmd sshopts cmdopts
+  cmd="$1"; shift
+  sshopts="${*%%--*}"; sshopts="${sshopts%% }"
+  cmdopts="${*#$sshopts}"; cmdopts="${cmdopts#*-- }"
+  eval ssh $sshopts -t $cmd $cmdopts
+}
+
+# need functions instead of aliases for completion
+rrsh() { _ssh_proxy "su -" "$@" }
+compdef rrsh=ssh
+
+ttsh() { _ssh_proxy "tmux last" "$@" }
+compdef ttsh=ssh
+
+rtsh() { _ssh_proxy "tmux new su -" "$@" }
+compdef rtsh=ssh
+
+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