diff options
author | Oliver Kiddle <opk@users.sourceforge.net> | 2000-05-12 13:16:52 +0000 |
---|---|---|
committer | Oliver Kiddle <opk@users.sourceforge.net> | 2000-05-12 13:16:52 +0000 |
commit | 56caa787a6660d5a5aa7531b1fe773332900d77d (patch) | |
tree | 46d3516cb61aab58f242389012abe6757bd5668f /Completion/Builtins/_hash | |
parent | 984bae21ba24710ff1fd24a8b9271ca4c89efbb4 (diff) | |
download | zsh-56caa787a6660d5a5aa7531b1fe773332900d77d.tar.gz zsh-56caa787a6660d5a5aa7531b1fe773332900d77d.tar.xz zsh-56caa787a6660d5a5aa7531b1fe773332900d77d.zip |
Use _arguments for hash completion and add + options for typeset (11347)
Diffstat (limited to 'Completion/Builtins/_hash')
-rw-r--r-- | Completion/Builtins/_hash | 43 |
1 files changed, 32 insertions, 11 deletions
diff --git a/Completion/Builtins/_hash b/Completion/Builtins/_hash index 0bda9df44..e748028fb 100644 --- a/Completion/Builtins/_hash +++ b/Completion/Builtins/_hash @@ -1,16 +1,37 @@ -#compdef hash +#compdef hash rehash -local expl +local state line expl common_args curcontext="$curcontext" +typeset -A opt_args -if [[ "$words[2]" = -*d* ]]; then - if compset -P 1 '*='; then - _wanted -C -d-value files expl directories _path_files -/ +common_args=( \ + '-d[use named directory hash table]' \ + '(-r -m -v)-f[rebuild hash table]' ) + +case ${words[1]} in + hash) + _arguments -C -s \ + '(-f -m -v)-r[empty hash table]' \ + '(-f -r)-m[treat arguments as patterns]' \ + '(-f -r -m)-v[list entires as they are added]' \ + "${common_args[@]}" \ + '(-d -f -r -m -v)*:hash:->hashval' && return 0 + ;; + rehash) + _arguments -C -s ${common_args[@]} && return 0 + ;; +esac + +if [[ $state = hashval ]]; then + if (( $+opt_args[-d] )); then + if compset -P 1 '*='; then + _wanted -C value files expl directories _path_files -/ + else + _wanted -C name named-directories expl 'named directory' \ + compadd -q -S '=' - "${(@k)nameddirs}" + fi + elif compset -P 1 '*='; then + _wanted -C value values expl 'executable file' _files -g '*(-*)' else - _wanted -C -d named-directories expl 'named directory' \ - compadd -q -S '=' - "${(@k)nameddirs}" + _wanted -C name commands expl command compadd -q -S '=' - "${(@k)commands}" fi -elif compset -P 1 '*='; then - _wanted -C value values expl 'executable file' _files -g '*(-*)' -else - _wanted -C name commands expl command compadd -q -S '=' - "${(@k)commands}" fi |