Difference between revisions of "Command/define"
< Command
Jump to navigation
Jump to search
(Update: \define does, in fact, happily redefine stuff) |
|||
Line 15: | Line 15: | ||
<tr valign="top" class="third"> | <tr valign="top" class="third"> | ||
<td class="cmd">{...}</td> | <td class="cmd">{...}</td> | ||
− | <td> | + | <td>''macro contents''</td> |
</tr> | </tr> | ||
</table> | </table> | ||
Line 21: | Line 21: | ||
== Description == | == Description == | ||
− | + | ||
+ | * In MkII, {{cmd|define}} is like the TeX primitive {{tex|def}}: it defines a new TeX macro. | ||
+ | * In MkIV {{cmd|define}} is like {{tex|unexpanded}}{{tex|def}}. | ||
The optional bracketed argument denotes the number of parameters you can give | The optional bracketed argument denotes the number of parameters you can give | ||
− | to your command. | + | to your command. ''macro contents'' is the result when the macro gets expanded. |
== Pitfalls == | == Pitfalls == |
Revision as of 20:26, 5 December 2012
\define
Syntax
\define[...]\command{...} | |
[...] | number |
{...} | macro contents |
Description
- In MkII, \define is like the TeX primitive \def: it defines a new TeX macro.
- In MkIV \define is like \unexpanded\def.
The optional bracketed argument denotes the number of parameters you can give to your command. macro contents is the result when the macro gets expanded.
Pitfalls
\define
does not use \long, that means in MkII
multiple paragraphs (e.g. through \par or \endgraf)
inside arguments will not work.
The name of the new command may not include numbers.
Example
% wiki mode=mkiv \define\hello{Good morning} % You may not use numbers % \define[1]\mp3{The ID3 Tag of the MP3 file is: #1} % but this will work: \define[1]\mpThree{The ID3 Tag of the MP3 file is: #1} % You can use non-ASCII characters in MkIV, but not in MkII. % This example is compiled using mkiv. \define[1]\KüFst{Küstenfunkstelle, #1!} \starttext \hello \KüFst{12} \stoptext
See also
Help from ConTeXt-Mailinglist/Forum
All issues with: