LATEX-L Archives

Mailing list for the LaTeX3 project

LATEX-L@LISTSERV.UNI-HEIDELBERG.DE

Options: Use Forum View

Use Monospaced Font
Show Text Part by Default
Show All Mail Headers

Message: [<< First] [< Prev] [Next >] [Last >>]
Topic: [<< First] [< Prev] [Next >] [Last >>]
Author: [<< First] [< Prev] [Next >] [Last >>]

Print Reply
Subject:
From:
Joseph Wright <[log in to unmask]>
Reply To:
Mailing list for the LaTeX3 project <[log in to unmask]>
Date:
Sat, 20 Aug 2011 18:56:08 +0100
Content-Type:
text/plain
Parts/Attachments:
text/plain (112 lines)
Hello Will,

Yuo may remember that l3keys started life as a more-or-less direct
conversion of pgfkeys to expl3 syntax. Over time, it's evolved somewhat,
but I think we can still look to pgfkeys for inspiration. This will show
up in my comments. I'm also imagining that as I'm 'responsible' for
l3keys in many ways, I'll be writing any new functionality (which I'm
perfectly happy with).

> 1.
> 
> It seems a bit strange that "generate-choices" requires two calls:
> 
> \keys_define:nn {fontspec-preparse} {
>   Renderer .choice-code:n = { ... } ,
>   Renderer .generate-choices:n = {AAT,ICU,Graphite,Full,Basic}
> }
> 
> (Especially when the code is quite long, the final line can get a bit lost.)
> What do you think of an additional keys function on the lines of:
> 
> \keys_define:nn {fontspec-preparse} {
>   Renderer .choices:nn = {AAT,ICU,Graphite,Full,Basic}{ ... }
> }
> 
> (Actually now I ponder this a little more I seem to remember it was a design goal for l3keys not to have key functions that take multiple arguments...am I recalling correctly? If that is the case, do we want to reconsider this?)

Originally, l3keys followed pgfkeys in having multi-argument keys: we
originally had '.choices:nn'! However, it seemed to me at the time that
the concept with a key sis that you set some key to some value, and that
this worked best in a one-to-one fashion. Thus l3keys has nothing
directly equivalent to pgfkeys' ".code 2 args", ".code args" or similar.

I'd agree that this may not be ideal in this particular case, as choices
are somewhat different from other ideas. I'm happy to make this switch
if it feels overall more 'natural' to do ".choices:nn". After all, the
entire idea of l3keys is to make defining key-value input as easy as
possible.

> 2.
> 
> There is currently a conditional "\keys_if_exist:nnTF" (and friends). What do you think of, additionally, "\keys_if_choice_exist:nnnTF" for which, say,
> 
>    \keys_if_choice_exist_p:nnn {fontspec-preparse} {Renderer} {AAT}
> 
> returns true?

Easy to implement, as if is simply an alternative take on
\keys_if_exist:nnTF. One obvious question is whether you check that
<key> is a choice in the first place, and if not what the 'correct'
answer is

  \keys_if_choice_exist_p:nnn { <fam> }{ <some-non-choice-key> }
    { <whatever> }

> 3.
> 
> I think it's generally useful to be able to filter lists of keys into their various modules. (Well, I do it in fontspec and it's the kind of thing that makes inheritance of values easy.)
> 
> For example, given a keyval list #1 it's often nice to be able to say
> 
> \keys_set:nn {foo} {#1}
> ...
> \keys_set:nn {bar} { <remainder of keys not set by "foo"> }
> 
> In xkeyval this is done in a simple manner by assigning all unset keys to a macro that can be accessed later; e.g., if it were like this in l3keys:
> 
> \keys_set:nn {foo} {#1}
> ...
> \keys_set:nV {bar} \l_keys_previous_unset_clist
> 
> You could also imagine doing it more explicitly with a "filtering" function:
> 
> \keys_filter:nnNN {foo} {#1} \l_keys_included_clist \l_keys_leftover_clist
> \keys_set:nV {foo} \l_keys_included_clist
> ...
> \keys_set:nV {bar} \l_keys_leftover_clist
> 
> 
> I'll provide my own local definition of the xkeyval approach in fontspec; do you think one of these should be added to l3keys proper? If the former, I imagine it would have to act in concert with the current "unknown" key setting. But I'm more in favour of the latter choice because it would then not conflict with current error handling.

When I was writing l3keys, this idea was not really available in
pgfkeys. However, there is now a  filter add-on to pgfkeys which does
exactly what you describe. (See the Tikz manual, section 'Key
Filtering'.) I find some of the current pgfkeys approach a bit hard to
follow, so if we do want to go this way will probably come up with a
proposal of my own. I'll come back on this once I've given it some more
thought, and hopefully will have an interface idea.

> 4.
> 
> Implicit mapping for multiple key choices; what do you think the expected behaviour is here?
> 
> \keys_define:nn {foo}
>   {
>     key .choice: ,
>     key / aaa .code:n = \typeout{aaa} ,
>     key / bbb .code:n = \typeout{bbb} ,
>   }
> \keys_set:nn {foo} {key={aaa,bbb}}
> 
> I would be inclined to disallow "," inside a choice name (if that's not already the case) and automatically map over this list. Is this a bad idea? (Of course, happy to do this manually in my own code.)

Here I'm a bit confused. The idea of a multiple-choice key is that they
are mutually-exclusive. I guess that you have a particular use case in
mind here, but I wonder if that means you have some badly-defined keys.
 Could you give more detail on this? (In general, if a key sets several
things then it is probably best defined as a meta-key which sets several
other keys. See for example the "mode" or "detect-all" keys in siunitx.)
--
Joseph Wright

ATOM RSS1 RSS2