Ceci est une ancienne révision du document !


— title: More than one optional argument category: programming tags: macros latex permalink: /FAQ-twooptarg date: 2014-06-10 —

If you've already read “[breaking the 9-argument limit](FAQ-moren9)”. you can probably guess the “simple” solution to this problem: command relaying.

LaTeX allows commands with a single optional argument thus: ```latex

\newcommand{\blah}[1][Default]{...}

```

You may legally call such a command either with its optional argument present, as `\blah[nonDefault]` or without, as `\blah`; in the latter case, the code of `\blah` will have an argument of `Default`.

To define a command with two optional arguments, we use the relaying technique, as follows: <!– {% raw %} –> ```latex \newcommand{\blah}[1][Default1]{%

\def\ArgI{{#1}}%
\BlahRelay

} \newcommand\BlahRelay[1][Default2]{%

% the first optional argument is now in
% \ArgI
% the second is in #1
...%

} ``` <!– {% endraw %} –> Of course, `\BlahRelay` may have as many mandatory arguments as are allowed, after allowance for the one taken up with its own optional argument&nbsp;&mdash; that is, 8.

Variants of `\newcommand` (and friends), with names like `\newcommandtwoopt`, are available in the [`twoopt`](https://ctan.org/pkg/twoopt) package. However, if you can, it's probably better to learn to write the commands yourself, just to see why they're not even a good idea from the programming point of view.

A command with two optional arguments strains the limit of what's sensible: obviously you can extend the technique to provide as many optional arguments as your fevered imagination can summon. However, see the comments on the use of the [`keyval`](https://ctan.org/pkg/keyval) package, in “[breaking the 9-argument limit](FAQ-moren9)”, which offers an alternative way forward.

If you must, however, consider the [`optparams`](https://ctan.org/pkg/optparams) or [`xargs`](https://ctan.org/pkg/xargs) packages. [`Optparams`](https://ctan.org/pkg/Optparams) provides a `\optparams` command that you use as an intermediate in defining commands with up to nine optional arguments. The documentation shows examples of commands with four optional arguments (and this from an author who has his own key-value package!).

The [`xargs`](https://ctan.org/pkg/xargs) package uses a key-value package ([`xkeyval`](https://ctan.org/pkg/xkeyval)) to _define_ the layout of the optional arguments. Thus ```latex \usepackage{xargs} … \newcommandx{\foo}[3][1=1, 3=n]{…} ``` defines a command `\foo` that has an optional first argument (default 1), a mandatory second argument, and an optional third argument (default n).

An alternative approach is offered by Scott Pakin's `newcommand` program, which takes a command name and a definition of a set of command arguments (in a fairly readily-understood language), and emits (La)TeX macros which enable the command to be defined. The command requires that a `Python` interpreter (etc.) be installed on your computer.

2_programmation/macros/macros_a_plusieurs_arguments_optionnels.1528031621.txt.gz · Dernière modification: 2018/06/03 15:13 par samcarter
CC Attribution-Share Alike 4.0 International
Driven by DokuWiki Recent changes RSS feed Valid CSS Valid XHTML 1.0