zsh-workers
 help / color / mirror / code / Atom feed
* PATCH: More useful setopt / unsetopt completion
@ 2014-08-28  9:48 Mikael Magnusson
  2014-08-30 20:50 ` Bart Schaefer
  0 siblings, 1 reply; 2+ messages in thread
From: Mikael Magnusson @ 2014-08-28  9:48 UTC (permalink / raw)
  To: zsh-workers

It was bothering me that setopt nono<tab> showed every options with
nono prefixed which isn't even valid, instead of completing nonomatch
and nonotify. I think this will be more helpful. I noticed that the
whole _options_set / _options_unset thing is pointless now that we have
_comp_caller_options, so maybe I'll post a followup patch adjusting the
documentation and removing those.

(and speaking of completion options, rcexpandparam is set, so $^ isn't
needed below)

---
 Completion/Zsh/Command/_setopt   | 22 ++++++++++++++--------
 Completion/Zsh/Command/_unsetopt | 10 ----------
 2 files changed, 14 insertions(+), 18 deletions(-)
 delete mode 100644 Completion/Zsh/Command/_unsetopt

diff --git a/Completion/Zsh/Command/_setopt b/Completion/Zsh/Command/_setopt
index f72c20d..e558b12 100644
--- a/Completion/Zsh/Command/_setopt
+++ b/Completion/Zsh/Command/_setopt
@@ -1,10 +1,16 @@
-#compdef setopt
+#compdef setopt unsetopt
 
-# If you first want to complete only unset options, un-comment the lines
-# setting the _options_unset  array and then use:
-#
-#   _options_unset || _options
-#
-# here.
+local expl ret=1
+local -a onopts offopts
+onopts=( ${(k)_comp_caller_options[(R)on]} )
+offopts=( ${(k)_comp_caller_options[(R)off]} )
+case $service in
+  setopt) onopts=(no$onopts) ;;
+  unsetopt) offopts=(no$offopts) ;;
+esac
+_wanted zsh-options expl 'zsh options (set)' \
+    compadd -J 'enabled options' -M 'M:_= M:{A-Z}={a-z}' -k - onopts && ret=0
+_wanted zsh-options expl 'zsh options (unset)' \
+    compadd -J 'disabled options' -M 'M:_= M:{A-Z}={a-z}' -k - offopts && ret=0
 
-_options
+return ret
diff --git a/Completion/Zsh/Command/_unsetopt b/Completion/Zsh/Command/_unsetopt
deleted file mode 100644
index 75a33e9..0000000
--- a/Completion/Zsh/Command/_unsetopt
+++ /dev/null
@@ -1,10 +0,0 @@
-#compdef unsetopt
-
-# If you first want to complete only unset options, uncomment the lines
-# setting the _options_set  array and then use:
-#
-#   _options_set || _options
-#
-# here.
-
-_options
-- 
1.9.0


^ permalink raw reply	[flat|nested] 2+ messages in thread

* Re: PATCH: More useful setopt / unsetopt completion
  2014-08-28  9:48 PATCH: More useful setopt / unsetopt completion Mikael Magnusson
@ 2014-08-30 20:50 ` Bart Schaefer
  0 siblings, 0 replies; 2+ messages in thread
From: Bart Schaefer @ 2014-08-30 20:50 UTC (permalink / raw)
  To: zsh-workers

On Aug 28, 11:48am, Mikael Magnusson wrote:
} Subject: PATCH: More useful setopt / unsetopt completion
}
} It was bothering me that setopt nono<tab> showed every options with
} nono prefixed which isn't even valid, instead of completing nonomatch
} and nonotify. I think this will be more helpful.

This looks fine to me, and the release is out now so you can commit it
if you like.


^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2014-08-30 20:49 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2014-08-28  9:48 PATCH: More useful setopt / unsetopt completion Mikael Magnusson
2014-08-30 20:50 ` Bart Schaefer

Code repositories for project(s) associated with this public inbox

	https://git.vuxu.org/mirror/zsh/

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).