about summary refs log tree commit diff
path: root/Completion/Base
diff options
context:
space:
mode:
authorPeter Stephenson <pws@users.sourceforge.net>2011-10-14 19:01:41 +0000
committerPeter Stephenson <pws@users.sourceforge.net>2011-10-14 19:01:41 +0000
commit8dc39360c92252207c9287e63d2f7bb457a77aaf (patch)
treeece269ed3cccc1bb094d7bbfc594467d0aa1c893 /Completion/Base
parentc70e44c9bd770b7ca5959841faa0857cc9496d8e (diff)
downloadzsh-8dc39360c92252207c9287e63d2f7bb457a77aaf.tar.gz
zsh-8dc39360c92252207c9287e63d2f7bb457a77aaf.tar.xz
zsh-8dc39360c92252207c9287e63d2f7bb457a77aaf.zip
29820: _pick_variant -b to match builtin
Diffstat (limited to 'Completion/Base')
-rw-r--r--Completion/Base/Utility/_pick_variant8
1 files changed, 7 insertions, 1 deletions
diff --git a/Completion/Base/Utility/_pick_variant b/Completion/Base/Utility/_pick_variant
index 01fa2b98f..9099e3599 100644
--- a/Completion/Base/Utility/_pick_variant
+++ b/Completion/Base/Utility/_pick_variant
@@ -6,7 +6,7 @@ local -A opts
 
 (( $+_cmd_variant )) || typeset -gA _cmd_variant
 
-zparseopts -D -A opts c: r:
+zparseopts -D -A opts b: c: r:
 : ${opts[-c]:=$words[1]}
 
 while [[ $1 = *=* ]]; do
@@ -19,6 +19,12 @@ if (( $+_cmd_variant[$opts[-c]] )); then
   return 0
 fi
 
+if [[ $+opts[-b] -eq 1 && -n $builtins[$opts[-c]] ]]; then
+  _cmd_variant[$opts[-c]]=$opts[-b]
+  (( $+opts[-r] )) && eval "${opts[-r]}=${_cmd_variant[$opts[-c]]}"
+  return 0
+fi
+
 output="$(_call_program variant $opts[-c] "${@[2,-1]}" </dev/null 2>&1)"
 
 for cmd pat in "$var[@]"; do