LATEX-L Archives

Mailing list for the LaTeX3 project

LATEX-L@LISTSERV.UNI-HEIDELBERG.DE

Options: Use Classic View

Use Monospaced Font
Show Text Part by Default
Condense Mail Headers

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

Print Reply
Sender: Mailing list for the LaTeX3 project <[log in to unmask]>
Date: Mon, 10 Aug 2009 16:56:07 +0100
Reply-To: Mailing list for the LaTeX3 project <[log in to unmask]>
Subject: Re: xparse
MIME-Version: 1.0
Content-Transfer-Encoding: 7bit
In-Reply-To: <[log in to unmask]>
Content-Type: text/plain; charset=ISO-8859-1
From: Joseph Wright <[log in to unmask]>
Parts/Attachments: text/plain (66 lines)
Will Robertson wrote:
> So let's say we want to define \foo that takes an argument but has to
> sanitise it in some way before processing it:
> 
>     \DeclareDocumentCommand \foo {m} {
>       \my_sanitise:Nn \l_sanitised_tl {#1}
>       \foo_internal:V \l_sanitised_tl
>     }
>     \cs_new:Nn \my_sanitise:Nn {
>       % do something with #1 and save it in \l_sanitised_tl
>     }
>     \cs_new:Nn \foo_internal:n {
>       % do whatever \foo is supposed to do with #1
>     }
>     \cs_generate_variant:Nn \foo_internal:n {V}
> 
> From my not in-depth understanding of xdoc2l3, this can be dramatically
> simplified (I imagine) with something like
> 
>     \DeclareDocumentCommand \foo { ?{\my_sanitise:n} } {
>       % do whatever \foo is supposed to do with #1
>     }
> 
> Just to confirm -- have I got this thing sort of right? :)
> 
> With this sort of example, it seems pretty clear that this can save a
> lot of code that's just shuffling arguments around. (In the same way
> that manual optional argument processing consists of lots of
> intermediate functions that simply pass their arguments around.)

Hello Will,

That was my understanding also.  The question is then whether we
want/need to support this for all argument types or just one (or more)
specific ones (or of course at all).

In the first case, the interface currently used by xparse doesn't really
work (I think). You need to go with something like xdoc2l3, where each
specifier has a "processing" argument. My worry with that is, as I've
said before, that it may be overly complex as a replacement for \newcommand.

On the other hand, if you only want post-processing for a limited number
of argument types then it should work.  For example, you can imagine
having an argument type p ( = processed) to handle mandatory arguments
with post-processing:

\DeclareDocumentCommand \foo { o p{<processing-here>} } {
  % Code using processed #2
}

or

\DeclareDocumentCommand \foo { o p\ProcessingFunction } {
  % Code using processed #2
}

(This depends on whether you envisage using a single token for
post-processing or allowing more than one processing function.)

The question is then how many types of argument need post-processing. If
it is only m => p, then this looks okay. Duplicating all of the
specifiers, one for post-processed and one not, takes us back to needing
to fundamentally re-think the plan.
-- 
Joseph Wright

ATOM RSS1 RSS2