zsh-workers
 help / color / mirror / code / Atom feed
From: Sven Wischnowsky <wischnow@informatik.hu-berlin.de>
To: zsh-workers@sunsite.auc.dk
Subject: Re: PATCH: completion in quotes
Date: Mon, 7 Jun 1999 14:42:36 +0200 (MET DST)	[thread overview]
Message-ID: <199906071242.OAA07060@beta.informatik.hu-berlin.de> (raw)
In-Reply-To: Peter Stephenson's message of Mon, 07 Jun 1999 13:54:51 +0200


Peter Stephenson wrote:

> Sven Wischnowsky wrote:
> > This makes completion always work on whole quoted strings. It has the
> > special casing for string that start with a quote as discussed last
> > week. The code is very careful to change the word as few as possible,
> > I hope it is even better than what Bart suggested in 6471.
> 
> Wow.  It looks like the compsys.yo chunk was just a repeat of the
> documentation for $compcontext, and there was some debugging code in
> _brace_parameter so it needed applying by hand, but I think it was all
> unambiguous.

Ugh. Sorry.

> > 1) The code tries to automatically insert closing quotes. This is also 
> >    done during menucompletion -- is this ok?
> 
> Maybe in principle this should be compstate-able, but I won't worry too
> much.

Hadn't thought of that... but I'll first let it sink in anyway.

> > 2) `compset -q' currently does nothing if the current word isn't
> >    quoted. This could be changed to always split the current word at
> >    spaces even if not inside quotes. Should we?
> 
> I'd say, not until there's a clear use for this, then (presumably) you can
> share code in cases which do or don't have quotes.  The spaces to split on
> in this case would have to have been put there explcitly by the completion
> code, wouldn't they?  Otherwise they'd have to be quoted already to get
> that far.  Or are you distinguishing between "zsh -c 'echo foo'" and "zsh
> -c echo\ foo"?  Ideally those two should be split in the same way.

(I take the double quotes as being meta-characters in this case.)

This is the thing I was thinking about. Here, `compset -q' will only
return true (and modify the parameters) in the first case, not in the
second one, because the code knows that there is/isn't a single quote 
at the beginning.

> > 4) I changed `_brace_parameters' to automatically insert closing
> >    quotes inside parameter expansions (`${"foo<TAB>'). This fails with 
> >    completeinword if there already was a closing quote on the line.
> >    I may have to rethink something here. Maybe this should always be
> >    done automatically without the completion widget having to bother
> >    about it. Probably in a way that closes the expansion automatically 
> >    only if there is no user-supplied -S suffix.
> 
> It could get quite icky if you're trying to close nested things all the
> time.  Anything simple and consistent would be OK.

Btw. When the code automatically inserts closing quotes, this is only
done for one level. If you use `compctl -h' or `compset -q' to
complete parts of:

  % foo 'bar "baz<TAB>

the code inserts only the ", not "', and only if there is no other
suffix worth inserting.


Bye
 Sven


--
Sven Wischnowsky                         wischnow@informatik.hu-berlin.de


             reply	other threads:[~1999-06-07 12:42 UTC|newest]

Thread overview: 4+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
1999-06-07 12:42 Sven Wischnowsky [this message]
  -- strict thread matches above, loose matches on Subject: below --
1999-06-07 11:55 Sven Wischnowsky
1999-06-07 10:54 Sven Wischnowsky
1999-06-07 11:54 ` Peter Stephenson

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=199906071242.OAA07060@beta.informatik.hu-berlin.de \
    --to=wischnow@informatik.hu-berlin.de \
    --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).