Zsh Mailing List Archive
Messages sorted by:
Reverse Date,
Date,
Thread,
Author
Re: About the new long/short options changes
- X-seq: zsh-workers 15526
- From: Sven Wischnowsky <wischnow@xxxxxxxxxxxxxxxxxxxxxxx>
- To: zsh-workers@xxxxxxxxxx
- Subject: Re: About the new long/short options changes
- Date: Mon, 30 Jul 2001 10:38:56 +0200 (MET DST)
- In-reply-to: <200107300822.KAA27055@xxxxxxxxxxxxxxxxxxxxxxxxxxxx>
- Mailing-list: contact zsh-workers-help@xxxxxxxxxx; run by ezmlm
I wrote:
> ...
>
> Second, trying `gzip <TAB>' with `prefix-needed == false' didn't show
> files because of the return value of _arguments. We've (ok: I) changed
> this several times now and can only hope it doesn't interfere with other
> complicated functions using _arguments.
Urgh. Thinko. This doesn't work because there may be no matches in the
completions generated by the calling function. Damn.
I comment this out for now. If noone sees a better solution, the thing
to do might be to make all functions using `->state' actions compare
$compstate[nmatches] to its previous value on exit.
Bye
Sven
? Completion/Unix/Command/_gzip#
Index: Completion/Base/Utility/_arguments
===================================================================
RCS file: /cvsroot/zsh/zsh/Completion/Base/Utility/_arguments,v
retrieving revision 1.8
diff -u -r1.8 _arguments
--- Completion/Base/Utility/_arguments 2001/06/06 09:31:54 1.8
+++ Completion/Base/Utility/_arguments 2001/07/30 08:36:39
@@ -428,6 +428,14 @@
if [[ -n "$aret" ]]; then
[[ -n $rawret ]] && return 300
+
+### Returning non-zero would allow the calling function to add its own
+### completions if we generated only options and have to use a ->state
+### action. But if that then doesn't generate matches, the calling
+### function's return value would be wrong unless it compares
+### $compstate[nmatches] to its previous value. Ugly.
+###
+### return 1
else
[[ -n "$noargs" && nm -eq "$compstate[nmatches]" ]] && _message "$noargs"
fi
Index: Src/Zle/computil.c
===================================================================
RCS file: /cvsroot/zsh/zsh/Src/Zle/computil.c,v
retrieving revision 1.70
diff -u -r1.70 computil.c
--- Src/Zle/computil.c 2001/07/27 12:56:57 1.70
+++ Src/Zle/computil.c 2001/07/30 08:36:40
@@ -4281,9 +4281,7 @@
SWITCHHEAPS(oldheap, compheap) {
while ((n = *args++)) {
endcmgroup(NULL);
- begcmgroup(n, 0);
- endcmgroup(NULL);
- begcmgroup(n, CGF_NOSORT);
+ begcmgroup(n, CGF_NOSORT|CGF_UNIQCON);
endcmgroup(NULL);
begcmgroup(n, CGF_UNIQALL);
endcmgroup(NULL);
@@ -4291,7 +4289,9 @@
endcmgroup(NULL);
begcmgroup(n, CGF_UNIQALL);
endcmgroup(NULL);
- begcmgroup(n, CGF_NOSORT|CGF_UNIQCON);
+ begcmgroup(n, CGF_NOSORT);
+ endcmgroup(NULL);
+ begcmgroup(n, 0);
}
} SWITCHBACKHEAPS(oldheap);
--
Sven Wischnowsky wischnow@xxxxxxxxxxxxxxxxxxxxxxx
Messages sorted by:
Reverse Date,
Date,
Thread,
Author