From 5e3e05a6079a9d0c251f8ead1029792aaf9ad6ca Mon Sep 17 00:00:00 2001 From: Tanaka Akira Date: Wed, 3 May 2000 11:38:32 +0000 Subject: 11109: Completion/X/_xauth: new completion for xauth. --- Completion/X/_xauth | 115 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 115 insertions(+) create mode 100644 Completion/X/_xauth (limited to 'Completion/X') diff --git a/Completion/X/_xauth b/Completion/X/_xauth new file mode 100644 index 000000000..9461ac889 --- /dev/null +++ b/Completion/X/_xauth @@ -0,0 +1,115 @@ +#compdef xauth + +local state context line expl +typeset -A opt_args +local tmp cmd + +_arguments -s \ + '-f[specify authfile]:authfile:_files' \ + '(-q)-v[verbose mode]' \ + '(-v)-q[quiet mode]' \ + '-b[break locks]' \ + '-i[ignore locks]' \ + '*::command:->command' + +while [[ -n "$state" ]]; do + tmp="$state" + state= + case "$tmp" in + command) + if (( CURRENT == 1 )); then + state=subcommands + else + cmd="$words[1]" + curcontext="${curcontext%:*:*}:xauth-${cmd}:" + case "$cmd" in + add) + _arguments \ + ':display name:->displayname' \ + ':protocol name:->protocolname' \ + ':hexkey:' + ;; + + generate) + if (( CURRENT == 2 )); then + state=displayname + elif (( CURRENT == 3 )); then + state=protocolname + else + case "$words[CURRENT-1]" in + timeout) _message 'timeout(seconds)';; + group) _message 'group-id';; + data) _message 'hexdata';; + *) + _wanted options expl 'xauth generate options' \ + compadd trusted untrusted timeout group data + ;; + esac + fi + ;; + + extract|nextract) + case "$CURRENT" in + 2) _wanted files expl 'filename to write auth data' _files;; + *) state=displayname;; + esac + ;; + + list|nlist) + state=displayname + ;; + + merge|nmerge) + _wanted files expl 'filename to read auth data' _files + ;; + + remove) + state=displayname + ;; + + source) + _wanted files expl 'filename to source' _files + ;; + + info|exit|quit|\?) + ;; + + help) + state=subcommands + ;; + esac + fi + ;; + + subcommands) + tmp=( + 'add:add entry' + 'generate:use server to generate entry' + 'extract:extract entries into file' + 'nextract:numerically extract entries' + 'list:list entries' + 'nlist:numerically list entries' + 'merge:merge entries from files' + 'nmerge:numerically merge entries' + 'remove:remove entries' + 'source:read commands from file' + 'info:print information about entries' + 'exit:save changes and exit program' + 'quit:abort changes and exit program' + 'help:print help' + '?:list available commands' + ) + _describe 'xauth command' tmp -- + ;; + + protocolname) + _wanted values expl 'authorization protocol' \ + compadd MIT-MAGIC-COOKIE-1 XDM-AUTHORIZATION-1 SUN-DES-1 MIT-KERBEROS-5 + ;; + + displayname) + _wanted values expl 'display name' \ + compadd - ${${(f)"$(xauth list)"}%% *} || _x_display + ;; + esac +done -- cgit 1.4.1