From: Adam Spiers <adam@thelonious.new.ox.ac.uk>
To: zsh-workers@sunsite.auc.dk
Subject: Re: PATCH: completion for perldoc
Date: Tue, 7 Sep 1999 10:49:01 +0100 [thread overview]
Message-ID: <19990907104901.C7292@thelonious.new.ox.ac.uk> (raw)
In-Reply-To: <199909070832.KAA03607@beta.informatik.hu-berlin.de>; from Sven Wischnowsky on Tue, Sep 07, 1999 at 10:32:00AM +0200
Sven Wischnowsky (wischnow@informatik.hu-berlin.de) wrote:
> Adam Spiers wrote:
> > - Why can't you have multiple MESSAGE:ACTION pairs with the
> > *:MESSAGE:ACTION form? I'm having to resort to using an auxiliary
> > function, e.g.:
>
> There three forms that allow you to specify completion for
> (non-option-) arguments:
[snip]
Sorry, badly phrased question. I understood the three forms;
my question was, why can't the third form:
> `*:mesg:action'
> specify completion for `all other' arguments
look like this:
`*:mesg1:action1:mesg2:action2:...'
?
So that instead of this (which now works!) ...
_perldoc () {
_arguments -s \
'-h:help:' \
'(-q)-f:Perl built-in function:_perl_builtin_funcs' \
'(-f)-q:Perl FAQ keyword:' \
'*:Perl pod pages:_perl_pods'
}
_perl_pods () {
local nm="$compstate[nmatches]"
_perl_modules
_perl_basepods
_path_files -J 'Perl modules and .pods' -/ -g '*.(pod|pm)'
[[ nm -ne "$compstate[nmatches]" ]]
}
I could do something like:
_perldoc () {
_arguments -s \
'-h:help:' \
'(-q)-f:Perl built-in function:_perl_builtin_funcs' \
'(-f)-q:Perl FAQ keyword:' \
'*:Perl modules:_perl_modules:Perl base pods:_perl_basepods:Perl modules and .pods:_path_files -/ -g \*.\(pod\|pm\)'
}
> > - Is it possible to do something like (-foo)*:MESSAGE:ACTION, i.e.
> > specifying completion for normal args only if -foo hasn't been
> > specified?
>
> There is no direct support for this. I'm not sure what you really want
> to have, but I think (or: hope) you can do it with:
>
> `-foo:*:mesg1:action1' '*:mesg2:action2'
>
> which makes *all* arguments after the option `-foo' be completed
> with `action1' (if that is empty, nothing will be completed, of
> course), and if `-foo' is not given, the second specification will
> be used
>
> This can then be used together with some trickery for `action1' to
> achieve almost everything. If that is not enough or too clumsy to use,
> I'd like to see the real world example that made you wish for this.
> And then I'll think about ways to make this easier.
The example I'm thinking of is (surprise, surprise) perldoc. The word
after -f is now correctly completed to Perl's built-in functions.
However, I want to prevent further completions if `-f print ' (say)
has been typed in, since `perldoc -f print Perl::Module' is
nonsensical to perldoc.
`(-q)-f:built-in function:_perl_builtin_func:*:'
works, but
`(-f)-q:FAQ keyword::*:'
gets confused by the empty ACTION. I tried
`(-f)-q:FAQ keyword:():*:'
but then it doesn't print `FAQ keyword'.
next prev parent reply other threads:[~1999-09-07 9:49 UTC|newest]
Thread overview: 12+ messages / expand[flat|nested] mbox.gz Atom feed top
1999-09-07 8:32 Sven Wischnowsky
1999-09-07 9:49 ` Adam Spiers [this message]
-- strict thread matches above, loose matches on Subject: below --
1999-09-07 9:02 Sven Wischnowsky
1999-09-07 8:59 Sven Wischnowsky
1999-09-06 11:37 Sven Wischnowsky
1999-09-06 18:18 ` Adam Spiers
1999-09-06 18:21 ` Adam Spiers
1999-09-07 8:57 ` Peter Stephenson
1999-09-07 9:18 ` Adam Spiers
1999-09-06 9:28 Sven Wischnowsky
1999-09-06 10:07 ` Adam Spiers
1999-09-05 21:38 Adam Spiers
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=19990907104901.C7292@thelonious.new.ox.ac.uk \
--to=adam@thelonious.new.ox.ac.uk \
--cc=adam@spiers.net \
--cc=zsh-workers@sunsite.auc.dk \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
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).