Next: Inline Conditionals: @inline
, @inlineifelse
, @inlineraw
, Previous: Conditional Not Commands, Up: Conditionally Visible Text [Contents][Index]
The @if…
conditionals just described must be used only
with normal Texinfo source. For instance, most features of plain
TeX will not work within @iftex
. The purpose of
@if…
is to provide conditional processing for Texinfo
source, not provide access to underlying formatting features. For
that, Texinfo provides so-called raw formatter commands. They
should only be used when truly required (most documents do not need
them).
The first raw formatter command is @tex
. You can enter plain
TeX completely, and use ‘\’ in the TeX commands, by
delineating a region with the @tex
and @end tex
commands. All plain TeX commands and category codes are restored
within a @tex
region. The sole exception is that the
@
character still introduces a command, so that @end
tex
can be recognized. Texinfo processors will not output material
in such a region unless TeX output is being produced.
In complex cases, you may wish to define new TeX macros within
@tex
. You must use \gdef
to do this, not \def
,
because @tex
regions are processed in a TeX group. If you
need to make several definitions, you may wish to set
\globaldefs=1
(its value will be restored to zero as usual when
the group ends at @end tex
, so it won’t cause problems with
the rest of the document).
As an example, here is a displayed equation written in plain TeX:
@tex $$ \chi^2 = \sum_{i=1}^N \left (y_i - (a + b x_i) \over \sigma_i\right)^2 $$ @end tex
The output of this example will appear only in a printed manual. If you are reading this in a format not generated by TeX, you will not see the equation that appears in the printed manual.
Analogously, you can use @ifhtml … @end ifhtml
to
delimit Texinfo source to be included in HTML output only, and
@html … @end html
for a region of raw HTML.
Likewise, you can use @ifxml … @end ifxml
to delimit
Texinfo source to be included in XML output only, and @xml
… @end xml
for a region of raw XML. Regions of raw text in
other formats will also be present in the XML output, but with
protection of XML characters and within corresponding elements. For
example, the raw HTML text:
@html <br /> @end html
will be included in the XML output as:
<html> <br /> </html>
Again likewise, you can use @ifdocbook … @end ifdocbook
to delimit Texinfo source to be included in DocBook output only, and
@docbook … @end docbook
for a region of raw DocBook.
The behavior of newlines in raw regions is unspecified.
In all cases, in raw processing, @
retains the same meaning as
in the remainder of the document. Thus, the Texinfo processors must
recognize and even execute, to some extent, the contents of the raw
regions, regardless of the final output format. Therefore, specifying
changes that globally affect the document inside a raw region leads to
unpredictable and generally undesirable behavior. For example, using
the @kbdinputstyle
command inside a raw region is undefined.
The remedy is simple: don’t do that. Use the raw formatter commands
for their intended purpose, of providing material directly in the
underlying format. When you simply want to give different Texinfo
specifications for different output formats, use the
@if…
conditionals and stay in Texinfo syntax.