Frequently Asked Question List for TeX
New LaTeX users are often surprised that macro definitions containing non-letters, such as
\newcommand{\cul8r}{Goodbye!}
fail to compile. The reason is that the TeX macro language, unlike most programming languages, allows nothing but letters in macro names.
There are a number of techniques for defining a macro with a name like
\cul8r. Unfortunately, none of the techniques is particularly
good:
\csname…\endcsname to define and invoke the
macro:
\expandafter\newcommand\csname cul8r\endcsname{Goodbye!}
I said, ``\csname cul8r\endcsname''.
\newcommand{\DefineRemark}[2]{%
\expandafter\newcommand\csname rmk-#1\endcsname{#2}%
}
\newcommand{\Remark}[1]{\csname rmk-#1\endcsname}
...
\DefineRemark{cul8r}{Goodbye!}
...
\Remark{cul8r}
8 is a letter:
\catcode`8 = 11
\newcommand{\cul8r}{Goodbye!}
I said, ``\cul8r''.
\cul8r can be used directly8 (such as
numbers or dimensions; so
\setlength{\paperwidth}{8in} tells us:
```latex
! Missing number, treated as zero.\cul which must always be followed by
8r:
\def\cul8r{Goodbye!}
I said, ``\cul8r''.
\cul8r can be used directly\cul is followed by anything other
than 8r, with a confusing diagnostic —
\cul99 produces:
! Use of \cul doesn't match its definition.
<*> \cul9
9
(which would confuse someone who hadn’t even realised there
was a definition of \cul in the document).
\cul, if any;
as a result, the technique cannot be used to define both a
\cul8r and, say, a \cul123 macro in the same
document.Technique 3 is in fact commonly used — in a limited form — within
most LaTeX packages and within LaTeX itself. The convention is to
use @ within the names of internal macros to hide them
from the user and thereby prevent naming conflicts. To this end,
LaTeX automatically treats @ as a letter while
processing classes and packages and as a non-letter while processing
the user’s document. The key to this technique is the separation:
internally a non-letter is used for macro names, and the user doesn’t
see anything of it, while the status remains “frozen” in all the
definitions created within the class or package. See
\@ and @ in macro names for
more information.
Note that analogous use of technique 3 in this example would give us
\begingroup
\catcode`8 = 11
\gdef\cul8r{Goodbye!}
\gdef\later{\cul8r}
\endgroup
I said, ``\later''.
which works, but rather defeats the object of the exercise.
(\later has the “frozen” catcode for “8”, even though the value
has reverted to normal by the time it’s used; note, also, the use of
the primitive command \gdef, since \newcommand can’t make a
macro that’s available outside the group.)
Recommendation: Either choose another mechanism (such as
\DefineRemark above), or choose another name for your macro, one
that contains only ordinary letters. A common approach is to use
roman numerals in place of arabic ones:
\newcommand{\culVIIIr}{Goodbye!}
which rather spoils the intent of the joke implicit in the example
\cul8r!
FAQ ID: Q-linmacnames
Tags: macros