diff options
Diffstat (limited to 'etc/completions/_sshfs')
-rw-r--r-- | etc/completions/_sshfs | 118 |
1 files changed, 0 insertions, 118 deletions
diff --git a/etc/completions/_sshfs b/etc/completions/_sshfs deleted file mode 100644 index b0adbaa..0000000 --- a/etc/completions/_sshfs +++ /dev/null @@ -1,118 +0,0 @@ -#compdef sshfs -## Since _user_at_host was a little inflexible, -## I ripped the responsible parts from _ssh. -## In future, sshfs should be handled by _ssh as well -## Copyright goes to whoever wrote _ssh (if in doubt, the zsh dudes) - -typeset expl lstate tmp - -_remote_files () { - # There should be coloring based on all the different ls -F classifiers. - local expl rempat remfiles remdispf remdispd args suf ret=1 - - if zstyle -T ":completion:${curcontext}:files" remote-access; then - zparseopts -D -E -a args p: 1 2 4 6 F: - if [[ -z ${QIPREFIX} ]] - then rempat="${PREFIX%%[^./][^/]#}\*" - else rempat="${(q)PREFIX%%[^./][^/]#}\*" - fi - remfiles=(${(M)${(f)"$(_call_program files ssh -o BatchMode=yes ${args} -a -x ${IPREFIX%:} ls -d1FL "${rempat}" 2>/dev/null)"}%%[^/]#(|/)}) - compset -P '*/' - compset -S '/*' || suf='remote file' - - remdispf=(${remfiles:#*/}) - remdispd=(${(M)remfiles:#*/}) - - _tags files - while _tags; do - while _next_label files expl ${suf:-remote directory}; do - [[ -n ${suf} ]] && compadd "${@}" "${expl[@]}" -d remdispf \ - ${(q)remdispf%[*=@|]} && ret=0 - compadd ${suf:+-S/} "${@}" "${expl[@]}" -d remdispd \ - ${(q)remdispd%/} && ret=0 - done - (( ret )) || return 0 - done - return ret - else - _message -e remote-files 'remote file' - fi -} - -_arguments \ - '-V[version]' \ - '-p:tcp port:' \ - '-C[compression]' \ - '-o:options:_values -s , "sshfs or fuse or mount options" reconnect sshfs_sync no_readahead sshfs_debug cache=:cache\ setting:(yes no) cache_timeout=:seconds: cache_stat_timeout=:seconds: cache_dir_timeout=:seconds: cache_link_timeout=:seconds: ssh_command=:ssh\ command:_command_names directport=:port: SSHOPT=:ssh\ option: default_permissions allow_other allow_root kernel_cache large_read direct_io max_read=:size: hard_remove debug fs_name=:name: use_ino readdir_ino' \ - '-d[debug]' \ - '-f[foreground]' \ - '-s[disable multithreaded operation]' \ - '-r[mount read-only]' \ - '-h[help]' \ - ':remote directory:->userhost' \ - ':mountpoint:_files -/' - -_ssh_users () { - _combination -s '[:@]' my-accounts users-hosts users "${@}" -} - -_ssh_hosts () { - local -a config_hosts - local config - integer ind - - # If users-hosts matches, we shouldn't complete anything else. - if [[ "${IPREFIX}" == *@ ]]; then - _combination -s '[:@]' my-accounts users-hosts "users=${IPREFIX/@}" hosts "${@}" && return - else - _combination -s '[:@]' my-accounts users-hosts \ - ${opt_args[-l]:+"users=${opt_args[-l]:q}"} hosts "${@}" && return - fi - if (( ind = ${words[(I)-F]} )); then - config=${~words[ind+1]} - else - config="${HOME}/.ssh/config" - fi - if [[ -r ${config} ]]; then - local IFS=$'\t ' key hosts host - while read key hosts; do - if [[ "${key}" == (#i)host ]]; then - for host in ${(z)hosts}; do - case ${host} in - (*[*?]*) ;; - (*) config_hosts+=("${host}") ;; - esac - done - fi - done < "${config}" - if (( ${#config_hosts} )); then - _wanted hosts expl 'remote host name' \ - compadd -M 'm:{a-zA-Z}={A-Za-z} r:|.=* r:|=*' "${@}" ${config_hosts} - fi - fi -} - -while [[ -n ${state} ]]; do - lstate=${state} - state='' - case ${lstate} in - userhost) - if compset -P '*:'; then - _remote_files ${(kv)~opt_args[(I)-[FP1246]]/-P/-p} && ret=0 - elif compset -P '*@'; then - _wanted hosts expl 'remote host name' _ssh_hosts -S ':' - elif compset -S '@*'; then - _wanted users expl 'login name' _ssh_users -S '' - else - if (( $+opt_args[-l] )); then - tmp=() - else - tmp=( 'users:login name:_ssh_users -qS@' ) - fi - _alternative \ - 'hosts:remote host name:_ssh_hosts -S :' \ - "${tmp[@]}" - fi - ;; - esac -done |