zsh-workers
 help / color / mirror / code / Atom feed
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'.


  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).