texi2html script.| Portions of texi2html | |
| Copyright © 1999, 2000 Lionel Cons | |
| Copyright © 1999, 2000 Karl Berry | |
| Copyright © 1999, 2000 Olaf Bachmann | |
| Copyright © 2002, 2003, 2004, 2005, 2006, 2007 Patrice Dumas | |
| Copyright © 2001, 2002, 2003, 2004, 2005, 2006 Derek Price | |
| Copyright © many others. | |
| Portions of this manual | |
| Copyright © 1999, 2000 Karl Heinz Marbaise (manual) | |
| Copyright © 2003, 2007 Derek Price (manual) | |
| Copyright © 2003, 2004, 2005, 2006, 2007 Patrice Dumas (manual) | 
Permission is granted to make and distribute verbatim copies of this manual provided the copyright notice and this permission notice are preserved on all copies.
Permission is granted to copy and distribute modified versions of this manual under the conditions for verbatim copying, provided that the entire resulting derived work is distributed under the terms of a permission notice identical to this one.
Permission is granted to copy and distribute translations of this manual into another language, under the above conditions for modified versions, except that this permission notice may be stated in a translation approved by the Free Software Foundation.
| Portions of texi2html | |
| Copyright © 1999, 2000 Lionel Cons | |
| Copyright © 1999, 2000 Karl Berry | |
| Copyright © 1999, 2000 Olaf Bachmann | |
| Copyright © 2002, 2003, 2004, 2005, 2006, 2007 Patrice Dumas | |
| Copyright © 2001, 2002, 2003, 2004, 2005, 2006 Derek Price | |
| Copyright © many others. | |
| Portions of this manual | |
| Copyright © 1999, 2000 Karl Heinz Marbaise (manual) | |
| Copyright © 2003, 2007 Derek Price (manual) | |
| Copyright © 2003, 2004, 2005, 2006, 2007 Patrice Dumas (manual) | 
Permission is granted to make and distribute verbatim copies of this manual provided the copyright notice and this permission notice are preserved on all copies.
Permission is granted to copy and distribute modified versions of this manual under the conditions for verbatim copying, provided that the entire resulting derived work is distributed under the terms of a permission notice identical to this one.
Permission is granted to copy and distribute translations of this manual into another language, under the above conditions for modified versions, except that this permission notice may be stated in a translation approved by the Free Software Foundation.
| [ < ] | [ > ] | [Contents] | [Index] | [ ? ] | 
This manual, last updated 30 June 2010, describes version 4.13
of the texi2html Perl script which converts
Texinfo into HTML.
Please send bug reports concerning this manual to the Texi2HTML developement list bug-texinfo@gnu.org. Please state the exact version of the manual which contains the bug, as given above.
This manual is currently under construction and of course incomplete. ;-)
| 1 Overview | ||
| 2 Obtaining texi2html | Obtaining a copy of the texi2htmlsource code distribution | |
| 3 Installation of texi2html | Installing texi2html | |
| 4 Invoking texi2html | Description of the command line options | |
| 5 Overview of initialization files content and loading | What kind of variables and subroutines appear in init files and how they are called | |
| 6 Fine tuning of the page layout | ||
| 7 Customizing HTML and text style in init files | Fine tuning of the HTML elements associated with the texinfo constructs | |
| Appendix A Internationalization | Help translating! | |
| B Incompatibilities with previous versions | ||
| C How little texi2html texinfo differs from GNU texinfo | The minor differences with regard with texinfo valid for makeinfo or texi2dvi | |
| Appendix D Command Line Option Index | ||
| Appendix E Variable Index | ||
| Appendix F Concept Index | ||
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
Texinfo is the official documentation format of the GNU project. It uses a single source file to produce both online information and printed output.
It is often desirable to have a way to produce HTML from Texinfo sources, as GNU-Info files are produced. It is much simpler to run a converter than it is to rewrite all the documentation in HTML, especially considering that there is so much Texinfo documentation in the world.
Some time ago makeinfo wasn’t able to produce
HTML output format, but people still wanted documentation in
HTML.  This was the birthing hour for
texi2html.  The basic purpose of texi2html
is to convert Texinfo documents into HTML.
Since then, HTML support in makeinfo has improved, but
texi2html is still stronger in many areas, including the degree to
which it allows customization.  With texi2html, some important
aspects of the resulting HTML files may be specified via command
line options, and configuration files provide an even finer degree of control
over the final output, allowing most every aspect of the final output not
specified in the Texinfo input file to be specified.  Configuration files are
written in perl, like the main program, and anything which may be
specified on the command line may also be specified within a configuration
file.
For an example of the kind of pages texi2html is capable of
producing, have a look at the following sites:
the Singular Manual,
the Cederqvist (CVS Manual).
| 1.1 Why texi2htmland notmakeinfo? | 
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
texi2html and not makeinfo?You would like to produce HTML files from your existing Texinfo
files?  There are two programs you can use to do this.  The first is
makeinfo (see Generating HTML in GNU Texinfo).
The second is texi2html.
The design goal of makeinfo’s HTML output was to produce
readable HTML output. It is now possible to use CSS
for HTML customization. Another possibility is to use intermediate 
formats, like docbook or makeinfo XML 
and XSL stylesheets to customize the resulting document. Still the 
output produced by makeinfo isn’t customizable.
The current development of texi2html tries to
provide for producing the more interesting and sophisticated HTML
pages that today’s Internet users have come to expect.
The goal behind texi2html is to generate attractive HTML by
default but also to allow users considerable freedom to affect the final
style and design of the output HTML pages.  This is achieved via
command line options and flexible configuration files. 
In contrast to the HTML produced by makeinfo --html (the
makeinfo program is part of the Texinfo distribution), the
texi2html program, among other differences, allows for the
customization of the entire page layout, including headers, footers, style
sheets, etc., allows for customization of the low level HTML
formatting, provides for splitting documents at various levels, and provides
for using the latex2html program to convert @tex sections of
the Texinfo source.
The focus on HTML is still present but with the help of the
customization files it is now possible to use texi2html to
produce other formats as well. texi2html may for example be
turned into a texinfo to roff translator with the help of a customization file 
provided with the distribution.
texi2html should reasonably convert all Texinfo
4.8 constructs.  If you find it does not, please send a bug report to the
texi2html-bug@nongnu.org email list.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
texi2htmlThe latest version of the source code for texi2html should be
available from
www.nongnu.org/texi2html/.
texi2html is also available with 
teTeX and 
TeX Live.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
texi2html| 3.1 Requirements | ||
| 3.2 Configuring the source and rebuilding | ||
| 3.3 Installing | ||
| 3.4 Advanced build features | 
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
To install texi2html, you must first obtain a copy of the
source distribution.  See section Obtaining texi2html.
texi2html requires perl version 
5.00405 or above to be run. An older perl 5 version with 
File::Spec is also likely to work.  The current version has 
been lightly tested on a wide range of perl, but has not been 
tested extensively on versions of perl below 5.6.
To play nice with encodings you 
also need the Encode and Unicode::Normalize modules.
To rebuild the script perl isn’t required in most cases. For more information about advanced build features, see Advanced build features.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
texi2html is a standard Automake-based distribution.
If you have a source version, you should run ./configure
to configure the sources and make to build the script.  
./configure
accepts options to select the installation directory for the ‘texi2html’
file, the default directories texi2html will use to look for
configuration files, and other details.  Run ./configure --help for
more information.
Running ./configure creates ‘texi2html_configured.pl’ from
‘texi2html.pl’, and also builds the make configuration
files (‘Makefile’s).
Running make combines five files into the final
‘texi2html’ program file:
Running make also rebuilds the documentation if needed.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
make install performs the installation to the locations specified to
the ./configure script.  This usually involves placing the actual
‘texi2html’ file someplace in your path, such as ‘/usr/local/bin’ or
‘/usr/bin’.
Installing texi2html in your path should be sufficient 
to run it.  To use default initialization files, or a configuration file for
LaTeX2HTML when using latex2html to convert @tex sections
(see section Expanding @tex and @math regions using LaTeX2HTML), install them in the package data directory
specified to configure.  This is ‘/usr/local/share/texi2html/’ by default,
but depends on the value of the ‘--pkgdatadir=dir’
 option passed to
the ./configure script. 
See section Use initialization files for fine tuning for more. 
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
This section documents features that are unlikely to be used but deserve a bit of documentation.
A ./configure switch, 
‘--with-unicode’
 allows to choose whether the unicode code should
be used or not. The default is to detect it with a test. This
code requires Encode and Unicode::Normalize modules.
A similar ./configure switch, 
‘--with-unidecode’
 allows to choose whether the perl module
Text::Unidecode should be used or not. The default is to detect it 
with a test. This code requires the Text::Unidecode module.
perl isn’t 
needed to build the script. the script is build by ‘./configure’ 
and a shell script launched by make which is a simple 
wrapper around a sed one-liner. The perl command
can be specified with the environment variable $PERL, otherwise
it is detected. perl is required to rebuild the documentation
as the HTML documentation is rebuild with texi2html
itself.
Old style translations are managed by a script manage_i18n.pl, 
created
by ./configure. manage_i18n.pl requires 
Data::Dumper to function normally. If this module isn’t there 
./configure detects it and manage_i18n.pl doesn’t
really rebuild the translations, but only copy files. It is possible
to use the ./configure switch ‘--enable-translations’
to override the ./configure detection. For more about 
translations, see Internationalization.
It is possible to build from outside of the source directory, for example the following should work:
tar xzvf texi2html-4.13.tar.gz mkdir texi2html_build cd texi2html_build ../texi2html-4.13/configure && make
All these features enables to build texi2html on a platform 
in order to run it on another platform, a kind of cross-building. The 
./configure switches and $PERL allows to specify 
everything needed for the build of the texi2html script.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
texi2htmlTo produce an HTML manual, run texi2html with a Texinfo
file as an argument.  For example, this manual is created with:
$ texi2html texi2html.texi
texi2html can accept more than one manual on the command line, and
will proceed with each of the manuals in turn.
The behaviour of texi2html may be changed with command line
options.  These command line options are always associated with corresponding
perl variables which may appear in init files, and these 
variables are presented in this chapter each time a switch is described. 
Boolean command line switches always have a corresponding negated switch, obtained by prepending ‘no’ or ‘no-’ to the switch name. For example ‘--nomenu’ does the reverse of ‘--menu’ .
When more than one manual is processed, the command line apply to all the manuals, except for command-line switches setting the output file names.
| 4.1 General options | ||
| 4.2 Specifying where to split the generated document | The HTML output may be split at different levels | |
| 4.3 Setting output file and directory names | ||
| 4.4 Specifying which regions get expanded | ||
| 4.5 Command line options related to Texinfo language features | ||
| 4.6 Page layout related command line options | Customizing page layout | |
| 4.7 Customizing the HTML and text style | ||
| 4.8 Expanding @texand@mathregions using LaTeX2HTML | ||
| 4.9 Use initialization files for fine tuning | Specifying initialization files for fine tuning | 
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
Miscellaneous general options:
Quit after num errors (default 1000), (variable $ERROR_LIMIT
).
Display a short help and exit.
Be verbose.
Display version information and exit.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
The HTML manual resulting from the processing of the Texinfo source
may be split into files at different levels.  This is specified with the
option ‘--split’
 which takes an argument, namely the level of splitting
(variable: $SPLIT
). This level may be: 
The document is split at @chapter, @appendix, or @unnumbered.
The document is split at the same places as it is using the ‘chapter’
argument, and also at @section, @appendixsec or
@unnumberedsec.
The document is split at every sectioning command.  It is not necessarily 
split at each node, if the @node structure doesn’t correspond with
the sectioning command structure (see below).
The document isn’t split. This is the default.
There are two kinds of commands which may be used to define sectioning
elements in Texinfo: @node and the structuring commands (@top,
@section, @appendixsubsec,  and so on).  A node just preceding
a structuring command is considered to be part of the same sectioning element
as that command.  If the @node Top isn’t associated with a structuring
command it also defines a sectioning element.
By default, nodes which aren’t associated with a structuring command are not
considered to be sectioning commands.  They are always considered to be part
of a sectioning element defined by a structuring command.  It is possible to
change this behaviour via the ‘--use-nodes’
 option (variable
$USE_NODES
).  In this case, nodes not associated with structuring
commands are also considered to be sectioning commands defining a sectioning
element. 
This default behaviour mimics texi2dvi behaviour, which ignores 
@node commands for the purprose of sectioning, while the second
looks like makeinfo behaviour (see Two Paths in GNU Texinfo). 
As an illustration, the following table shows how a sample Texinfo document is divided into sectioning elements when ‘--use-nodes’ is used and not:
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
The manual name is constructed by stripping the ‘.texi’, ‘.txi’, ‘.texinfo’, or ‘.txinfo’ extension from the Texinfo file name.
By default, texi2html generates the manual file in the current 
directory if the manual isn’t split. A ‘.html’ file extension is appended
to the manual name.
If the manual is split the files are put in a directory named after the manual name. The file name is constructed using the manual name as basename. An underscore followed by a number is appended to the basename for each files corresponding with sectioning elements, with the exception of the top element. For the top element there is nothing appended. The files containing special elements pages have an underscore and a 3 letter code corresponding to their content (‘toc’ for table of contents, ‘abt’ for about, ‘ovr’ for overview, ‘fot’ for footnotes if they are separated) appended. Lastly, an ‘.html’ file extension is appended.
Thus, if the texinfo file ‘afile.texi’ is processed and split at chapters into 3 files, the generated files (in directory ‘afile’) will be:
afile.html -->@node Topor@topsection afile_1.html --> Chapter 1 afile_2.html --> Chapter 2 afile_toc.html --> Table of Contents afile_abt.html --> About Page
This default behavior may be modified by several command line options. If the
output isn’t split, the prefix file name may be overrided by the
‘--output’
 command line option (variable $OUT
). If the output
is split, and ‘--output’
 is set, the files are placed in the directory
specified by the argument to the option.
The basename may be overridden with ‘--prefix’
 (variable
$PREFIX
).  If ‘--short-ext’
 is given, ‘.htm’ is appended
instead of ‘.html’ in the final step (variable $SHORTEXTN
).  
The ‘--top-file’
 option
overrides the top element file name (variable $TOP_FILE
).  This can
be used to name the top element file ‘index.html’.  Similarly,
‘--toc-file’
 changes the name of the table of contents file (variable
$TOC_FILE
).
Reusing the example above, but this time calling texi2html like so:
$ texi2html -split chapter -prefix manual -short-ext -top-file index.htm -toc-file contents.htm afile.texi
we get, in ‘manual’:
index.htm -->@node Topor@topsection manual_1.htm --> Chapter 1 manual_2.htm --> Chapter 2 contents.htm --> Table of Contents manual_abt.htm --> About Page
The file names generated by texi2html differ from those generated
by makeinfo. makeinfo uses the @setfilename
to determine the manual name(1). 
Also makeinfo uses the node name to construct
the file names while splitting at nodes.  
It is possible to get the same
behaviour out of texi2html by specifying the
‘--node-files’
 option (variable $NODE_FILES
).  
The default is false for this option.
If the output
isn’t split at nodes, texi2html will still output files named after
the nodes, without real content but redirecting to the right file.
This trick enables the generated HTML manual to be a
target for the cross-references of other manuals generated by
makeinfo or texi2html. 
In case the files are named after the node names, another command-line option, ‘--transliterate-file-names’
can be set to trigger ASCII transliteration of node file names 
(variable $TRANSLITERATE_FILE_NAMES
). Transliteration is set in the 
default case.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
The default for texi2html is to expand the @ifhtml, 
@html, and @menu regions, all the @ifnot regions 
except @ifnothtml, and no other @if regions.
It is possible to expand other regions by setting ‘--if<region>’
,
where ‘<region>’ is replaced by the literal name of the region (for
example, ‘--iftex’).  Symetrically, if ‘--no-if<region>’
 is
specified, the ‘<region>’ region is ignored.  The configuration file
array, @EXPAND
, holds the names of regions which should be 
expanded. The only region name present in @EXPAND in the default case 
is ‘html’. 
If ‘--nomenu’
 is set, the @menu sections are not expanded
(variable $SHOW_MENU
). The default is to expand @menu
sections.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
Miscalleneous Texinfo related things may be specified via command line options.
Sets the document language similar to the Texinfo directive,
@documentlanguage lang (variable $DOCUMENTLANGUAGE
).
The default is ‘en’, that is, use the english language strings.
Sets var.  Equivalent to, @set var 1, in Texinfo.
Clears var.  Equivalent to, @clear var, in Texinfo.
Prepend dir to the list of directories to search for
@include files (the associated array is @PREPEND_DIRS
,
empty in the default case).
Append dir to the list of directories to search for 
@include files (the associated array is @INCLUDE_DIRS
,
empty in the default case).
The include files are always searched for in the current directory.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
If the ‘--frames’
 option is specified, HTML frames 
are used.  A file describing the frame layout is generated, and the
document page is associated with a frame where the short table of
content appears (variable $FRAMES
). The default is not
to use frames.
It is also possible to suppress the section navigation panel with
‘--no-headers’
 (variable $HEADERS
, the default
is to output all the navigation panels), and to specify
whether footnotes should appear at the foot of the same page which contains
the reference to the note with ‘--footnote-style’
 set to
‘end’ or on a separate page with ‘--footnote-style’ 
set to ‘separate’ (variable $FOOTNOTESTYLE
).
The default is to have separated footnotes.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
Miscalleneous style changes may be achieved with command line options.
You can specify the document DTD by setting these options. 
‘--frameset-doctype’
 applies to the file describing the frames when 
frames are used (corresponding variables are $DOCTYPE
 and 
$FRAMESET_DOCTYPE
).
The default for the document doctype for HTML is:
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
And for the frameset doctype:
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Frameset//EN" "http://www.w3.org/TR/html4/frameset.dtd">
If this option is set, ISO8859 entities are used for some special symbols,
like Copyright © (variable $USE_ISO
). It is the default.
This command line switch provides for the inclusion of an external
Cascading Style Sheet (CSS) file.  More than one file may be
specified, and ‘-’ stands for the standard input (array
@CSS_FILES
). 
The option use is the same than for makeinfo and is described
extensively in HTML CSS in GNU Texinfo.
Briefly, the CSS @import lines from the external file
CSS file are pasted  before the
texi2html CSS rules, and the external file CSS
rules are pasted after the texi2html CSS rules.  
This command line switch provides for the inclusion of an reference
to a Cascading Style Sheet (CSS) URL.  More than one URL may be
specified (array @CSS_REFS
). 
This option sets the base directory for external HTML texinfo manuals 
(variable $EXTERNAL_DIR
).  Defaults to ‘../’.
If this option is set, HTML tables are used to format definition 
commands, rather than HTML definition tables (variable
$DEF_TABLE
). Default is false.
If this option is set, cross-references are given without section numbers
(variable $SHORT_REF
). Default is false.
If this option is set, sections are numbered (variable
$NUMBER_SECTIONS
).  This is the default.
If this option is set, links from headings to TOC entries are
created (variable $TOC_LINKS
). Default is false.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
@tex and @math regions using LaTeX2HTMLIt is possible to use LaTeX2HTML  
to process @tex regions and @math{} commands.  This is an
attractive way to display mathematical constructs in the HTML
manual.  The ‘--l2h’
 option activates this feature (variable
$L2H).  It is usually desirable to expand @tex sections when this
option is specified (see section Specifying which regions get expanded). The default is not to use this
feature.
The ‘--l2h-l2h=program’
 option enables changing the name/location
of the LaTeX2HTML program processing TeX regions (variable
$L2H_L2H
). The default is latex2html.
‘--l2h-tmp’
 sets the directory used for temporary
files, this name shouldn’t contain a dot ‘.’
(variable is $L2H_TMP
). Defaults to the current dir.
The file specified by ‘--l2h-file’ is used as LaTeX2HTML init file. It is searched at the same places than init files (see section Use initialization files for fine tuning), and the default is ‘l2h.init’.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
Initialization variables are read first from
‘/usr/local/share/texi2html/Config’ (the exact location being
changeable with the ‘--pkgdatadir=dir’
 option of the
configure script, see Installation of texi2html),
‘/usr/local/etc/texi2html/Config’ (the exact location being
changeable with the ‘--sysconfdir=dir’
 option of the
configure script, see Installation of texi2html), from ‘./Config’
then from ‘$HOME/.texi2html/Config’. Any command-line option 
can override the corresponding option set in init file, and the 
option ‘--init-file’
 specifies an init file to be loaded, with 
later settings overriding earlier ones.
The init files specified with ‘--init-file’ are searched first in the current directory, then in the ‘$HOME/.texi2html/’ directory, in the ‘/usr/local/etc/texi2html/’ directory and lastly in the ‘/usr/local/share/texi2html/’ directory.
A file is also included based on the language selected,
by $DOCUMENTLANGUAGE
, ‘--document-language’
 or 
@documentlanguage.
All the files with name the language name in 
‘/usr/local/share/texi2html/i18n/’, 
‘/usr/local/etc/texi2html/i18n/’,
‘$HOME/.texi2html/i18n/’ and then ‘./i18n/’ are included.
The default initialization options are defined in the
‘texi2html.init’ file contained in the texi2html
distribution (which gets included near the beginning of the
texi2html script that gets installed).
To customize texi2html it is best if you copy the
appropriate sections from the ‘texi2html.init’
contents into an appropriate local initialization file,
make the necessary changes there, and then have
texi2html read this initialization file by one of
the means described above.
Some init files are provided with texi2html, for example
‘book.init’ which produces an output more in line with 
what could be in a book, or ‘chm.init’ outputs files
that can be used to produce a CHM file.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
The initialization files are perl files, read as explained 
in Use initialization files for fine tuning. You don’t need to know much of perl
to do some simple changes in variable values, however, to be able to 
really take advantage of all the features of the initialization file,
a good knowledge of perl is required.
In initialization file two kind of variables appear. These are normal
variables (including arrays and hashes) and references on functions. 
The later permits the dynamic redefinition of functions used to produce
the HTML manual. You should be able to change the value of some  
normal variables without a deep knowledge of perl, by looking
at the existing examples. The possible mistakes in that case could be
omitted ‘;’, and bad quoting.
Initialization file are loaded from the main program by
the mean of a require, while in the Texi2HTML::Config
namespace. This means that the namespace of the main program and
the namespace of initialization files are distinct, which ensures
that no name clash should happen. The variables are declared with
use vars, such that it should be possible to use the 
use strict pragma in the initialization file code.
To avoid messing with the variables in the main namespace
all the global variables which could be of use in the init files 
are in the Texi2HTML namespace. Notice that the functions 
of the main program are still in the main namespace.
Since texi2html can proceed more than one file on the
command line, you should make sure that you initialize the variables
that are used during a manual formatting. The handlers explained
later can be used for that (see section Bypassing normal formatting).
| 5.1 Setting the encodings | ||
| 5.2 Redefining functions in initialization files | Function redefinition is achieved with redefinition of references on functions. | |
| 5.3 Conventions used for function prototypes | Conventions used in that manual for function reference prototypes display. | 
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
There are four encodings relevant for texi2html, they are
associated with corresponding configuration variables. If these 
variables are defined they
determine a corresponding value in %Texi2HTML::THISDOC
which is otherwise autodetected:
$DOCUMENT_ENCODING
 corresponds with 
the document encoding.
If defined, this variable sets 
$Texi2HTML::THISDOC{'DOCUMENT_ENCODING'}
.
If not defined, the encoding appearing in @documentencoding will
be used to set $Texi2HTML::THISDOC{'DOCUMENT_ENCODING'}
.
The @documentencoding value appears in 
$Texi2HTML::THISDOC{'documentencoding'}
.
$IN_ENCODING
 is set, this sets 
$Texi2HTML::THISDOC{'IN_ENCODING'}
.
Otherwise, when $Texi2HTML::THISDOC{'DOCUMENT_ENCODING'}
is set, $Texi2HTML::THISDOC{'IN_ENCODING'} is also set
if the encoding is supported by perl.
$OUT_ENCODING
. If defined, 
$Texi2HTML::THISDOC{'OUT_ENCODING'}
 is set accordingly.
If not defined, the value of
$Texi2HTML::THISDOC{'ENCODING_NAME'} 
or 
$Texi2HTML::THISDOC{'IN_ENCODING'}
is used if one of these variables is set.
$ENCODING_NAME
. It sets 
$Texi2HTML::THISDOC{'ENCODING_NAME'}
 if defined.
If unset the value of this variable is based on the
other ENCODING values, and if they are all undefined, the variable
$DEFAULT_ENCODING
 is used.
The values for the encoding related variables are set in the default 
init_out function reference (see section Preparing the output).
In general the $DOCUMENT_ENCODING and $IN_ENCODING are
set to the right values. $OUT_ENCODING is also rightly set
according to $ENCODING_NAME. 
To force a given encoding for the output, the
$ENCODING_NAME value may be set. The current default output encoding
is UTF-8. 
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
To redefine a function you must replace the corresponding funtion
reference with a reference on your function. 
Thus you should write your function, give it a name you
are certain it is unique in the Texi2HTML::Config namespace,
and override the value of the function reference with your own 
function reference. When another function from the main program
(or from another functions of an initialization file) calls the reference,
your function will be used. 
For example the function
reference corresponding with the function called when doing an
anchor is called $anchor. Thus if you want to override the
corresponding function
you could write:
# override the function reference
$anchor = \&my_own_function;
# the function reference now refers to
sub my_own_function {
# process arguments and return an html anchor
}
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
As the functions are defined by a reference name, we will always
use the reference name in function prototypes. For the function arguments
we will use \@array for a reference on an array and similarly 
\%hash for a reference on a hash.
Thus, the prototype for the function associated with the function reference ‘$formatting_function’ will be:
formatting_function takes as first argument $arg2,
as second argument a reference on an array \@arg2
and returns the formatted text $text.
To redefined the corresponding function, you should write:
$formatting_function = \&my_formatting_function
sub my_formatting_function($ $)
{
    my $arg1 = shift;
    my $arg2 = shift;
    # prepare $formatted_text
    .....
    return $formatted_text
}
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
Some features of the page layout might be specified with command line options, the corresponding variables are described in Page layout related command line options. Fine tuning of the page layout may be achieved with redefinition of other variables and function references in the initialization files.
| 6.1 The different categories of pages and sectioning elements | The different categories of pages. | |
| 6.2 Page layout and navigation panel overview | The elements of a page. | |
| 6.3 Customization of the navigation panels buttons | How to change the navigation panel. | |
| 6.4 Main program variables and usefull functions | The available main program variables and some usefull functions from the main program. | |
| 6.5 Preparing the output | Setting variables before the document production but after the texinfo parsing. | |
| 6.6 Finalizing the output | Cleaning after document generation. | |
| 6.7 Customizing the texi2htmlcss lines | Customizing css lines. | |
| 6.8 Customizing the page header | ||
| 6.9 Customizing the sections | ||
| 6.10 Customizing the page footer | ||
| 6.11 Special pages formatting | Customizing table of contents, top, about page. | |
| 6.12 Customizing the file and target names | ||
| 6.13 Generation of external files for index entries | Putting index entries in external files. | 
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
The following sectioning elements can be associated with pages:
These are normal sections or nodes. Their association with pages is determined by the splitting of the document. See section Specifying where to split the generated document.
The top element is the higher element in the document structure.
If there is a @top section it is the element associated with
that section. Otherwise it is the element associated with the 
@node Top. If there is no @node Top the first element is the 
top element.
The top element is formatted differently than a normal element if there
is a @top section or the @node Top isn’t associated 
with a sectioning command.
These elements are associated with pages if the document is split. There are four misc elements:
The About page shouldn’t be present for documents consisting
in only one sectioning element, or for documents unsplit and without
navigation information. The Footnote page should only
be present if the footnotes appear on a separated page 
(see section Page layout related command line options), however a footnote element is present if
the document isn’t split. The Table of contents should only
be formatted if @contents is present in the document.
Similarly the Overview should only appear if @shortcontents
or @summarycontents is present. The Table of contents and 
the Overview may also be directly included within the document, not
as separate pages (see section Table of contents and Short table of contents).
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
A page is broken up in three parts. A page header, the sections 
and a page footer. A common element in the page layout is a navigation
panel with icons or text linking to other sections or pages. Another
common element is a rule, separating sections or footer. The navigation
panel and the rules may be part of the sections or part of headers or
footers. You may use the variables $SMALL_RULE
, 
$DEFAULT_RULE
, $MIDDLE_RULE
 and $BIG_RULE
for rules of different sizes. The defaults are
$SMALL_RULE = '<hr size="1">'; $DEFAULT_RULE = '<hr>'; $MIDDLE_RULE = '<hr size="2">'; $BIG_RULE = '<hr size="6">';
In the header some important meta data may be defined, like the title or style information, and textual informations may be present in comments. All this doesn’t appear directly in the displayed HTML, though.
The page layout is mainly controlled by functions, the precise functions called depending on the document splitting. The navigation panel, however, can be customized with variables.
There are 19 items associated with elements. Each of these
is associated with a name and a reference to the 
element they represent, when such an element exists. 
The element is either a global element or an element relative to the current
element. The relative elements are found with respect with the document
structure defined by the section structuring commands (@chapter, 
@unnumbered…) or by the nodes (in that case the node 
directions are specified on node line or in menu organization).
These items are called element labels. They may be associated with 
a button (see section Specifying the buttons formatting), and used in the formatting functions 
(see section Main program variables and usefull functions).
Here is the list:
An empty button
Top element. The associated name is $TOP_HEADING
 if that variable is 
defined. This variable is not set by default.
Table of contents
About (help) page
Overview, short table of contents
First element in reading order
Last element in reading order
The first chapter with @printindex. The associated name 
is  $INDEX_CHAPTER
, if the variable is set. This variable is not set
by default.
The current element
Preceding element in reading order
Beginning of this chapter or previous chapter if the element is a chapter
Previous section on the same level
Previous node
Next element in reading order
Next chapter
Next section on the same level
Next node
Next node in node reading order
Up section
Up node
Forward element first in the next page (or file)
Backward element first in the previous page (or file)
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
A lot of customization of the navigation panel may be achieved without redefining functions, with variables redefinition. In case it isn’t enough, it is also possible to redefine the function doing the navigation panel formatting.
| 6.3.1 Controlling the navigation panel panel at a high level | Variables controlling the navigation panel at a global level | |
| 6.3.2 Specifying the buttons formatting | ||
| 6.3.3 Changing the navigation panel formatting | 
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
The global formatting of the navigation panels may be changed with the following variables:
$VERTICAL_HEAD_NAVIGATION
A vertical navigation panel will be used for the header navigation panel if this variable is true.
$ICONS
Icons are used instead of textual buttons if this variable is true.
$HEADERS
If this variable is false there is no section navigation, no navigation panels for the elements within the pages, only at the beginning and the end of the page (see section Page layout related command line options).
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
Several arrays and hashes enable a precise control on the buttons and their display. The following arrays determine the buttons present in navigation panels:
@SECTION_BUTTONS
This array is used for the navigation panel buttons present at the begining of sectioning elements. If split at node or section they are also used at the page footer, and in the case of section navigation at the page header.
@SECTION_FOOTER_BUTTONS
@NODE_FOOTER_BUTTONS
This array is used for the navigation panel buttons present at the footer of pages when split at node or at section.
If $WORDS_IN_PAGE
 is set and the output is split at nodes, these 
buttons are only present if there are more than $WORDS_IN_PAGE
words in the sectioning element text. This counting is very rough and include punctuation marks, html elements, numbers. The default is to include the buttons after 300 words.
@CHAPTER_BUTTONS
This array is used for the buttons appearing at the page footer if split at chapter, and at the page header if split at chapter and there is no section navigation.
@MISC_BUTTONS
These buttons appear at the beginning of special and sections and at the end of these section pages if the output is split.
@LINKS_BUTTONS
These are used for <link> elements if they are output in the
headers.
The array specify the buttons displayed in navigation panels, and how the button is displayed. Each element is associated with a button of the navigation panel from left to right. The signification of the array element value is the following:
The function is called with argument a boolean true if the navigation panel should be vertical. Should return the formatted button text.
The scalar value is printed. For some possibly usefull scalars, Accessing elements informations.
In this case the first array element should be a reference on text and the second element an element label. In that case a link to the element associated with the element label with the scalar value text is generated.
For example if the buttons array element is
[ 'Next', \$Texi2HTML::NODE{Next} ] 
The button will be a link to the next section with text 
$Texi2HTML::NODE{Next}
.
If icons are not used, the button is a link to the corresponding
element which text is defined by the value associated with the 
element label in the %NAVIGATION_TEXT
 hash, surrounded
by ‘[’ and ‘]’. If the element label is ‘ ’, there is
no ‘[’ and ‘]’. 
The element of the %NAVIGATION_TEXT hash are defined 
dynamically, in the init_out function reference
(see section Preparing the output).
If icons are used, the button is an image with file determined by
the value associated with the element label in the %ACTIVE_ICONS
hash if the the link really leads to an element, or in the %PASSIVE_ICONS
hash if there is no element to link to. Of course if there is a link to the 
element the icon links to that element. The button name and 
the button description are used in HTML attributes to have a textual 
description of the icon. The corresponding strings are in 
%BUTTONS_NAME
  for the button name and  %NAVIGATION_TEXT
for the description.
If $USE_ACCESSKEY
 is set, the accesskey attribute 
is used in navigation. In that case the %BUTTONS_ACCESSKEY
hash is used for the access key.
Similarly, if 
If $USE_REL_REV
 is set, the rel attribute is used 
in navigation. In that case the %BUTTONS_REL
 hash is used for 
the rel attribute.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
If you are not satisfied with this scheme, it is possible to control exactly the formatting of navigation panels by redefining a function reference. The function controlling the display of navigation panel is associated with the following function reference:
\@buttons is an array reference which should hold the specification of the buttons for that navigation panel. $vertical is true if the navigation panel should be vertical. Returns the formatted navigation panel in $navigation_text.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
In the functions controlling the page layout some global variables set by the main program are available, with value corresponding with the current layout element.
| 6.4.1 Accessing elements informations | Accessing information related with the different elements | |
| 6.4.2 Accessing global informations | Accessing global informations, like date, title… | |
| 6.4.3 Function usefull in page formatting | main program usefull functions | 
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
Four hashes are available, with key the elements labels (as described in Element labels) and values:
%Texi2HTML::NAME
The formatted element name
%Texi2HTML::HREF
The element hypertext reference
%Texi2HTML::NODE
The element node name
%Texi2HTML::NO_TEXI
The element name after removal of texi commands
If $USE_NODE_TARGET
 is set, the node anchors are used as 
target for the section HREF, if there is a node associated to
that section.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
Three kinds of global informations are available, miscalleneous global
strings, flags set by @set and special flags and section lines.
Some information may be set up by @-commands, by
a variable in the init file, and sometime on the command-line. 
This is the case, for example, for
@footnotestyle, ‘--footnote-style’ and $FOOTNOTESTYLE.
The value associated with these should be read by calling the get_conf
function, in the Texi2HTML::Config namespace, for example:
if (get_conf('footnotestyle') eq 'separate') { .... }
When it exists, the associated
variable that sets the default value have the same name, in upper case.
Currently the following information corresponding with @-commands 
is available through 
get_conf:
 kbdinputstyle, paragraphindent, setchapternewpage, headings,
 footnotestyle,
  exampleindent, firstparagraphindent, everyheading, everyfooting,
  evenheading, evenfooting, oddheading, oddfooting, setcontentsaftertitlepage,
 setshortcontentsaftertitlepage, frenchspacing, fillcolumn, documentlanguage,
 novalidate.
Information nthat can be set on the command line and in init files, or 
that could be modified on a per-output file basis are also available
through get_conf:
SPLITHow the manual is split.
SPLIT_SIZEThe split size, only relevant for info output.
doctypeThe current doctype.
headersTrue if headers are to be output.
The %Texi2HTML::THISDOC
 hash holds some global informations:
fulltitletitle set by @settitle. If there is no @settitle other 
possibilities are tried (@title, @shorttitlepage…).
fulltitle_no_texifulltitle without texi formatting
fulltitle_texifulltitle with texi commands
titletitle set by @title.
title_no_texititle without texi formatting
title_texititle with texi commands
authorAuthors list set by @author.
authorsA reference on an array containing each author set by @author.
copying_commentText appearing in @copying with all the texinfo commands removed,
put in comments.
programThe name and version of texi2html.
program_homepageHomepage for texi2html.
program_authorsAuthors of texi2html.
file_base_namebase name of the texinfo manual file.
filenameThis is a reference on a hash that holds the filenames for special elements.
These files may not be used in certain cases, for example the toc
element file name may not be relevant if table of contents is not output 
separately.
The keys are
docthe document file if not split, if split should be the top element file.
topTop element file name.
tocTable of contents element file name.
stocOverview (also called short table of contents) element file name.
aboutAbout element file name.
footFootnotes element file name.
frameMain frame file.
toc_frameTable of contents frame file name.
input_file_nameName of the texinfo manual file given on the command line.
destination_directoryDestination directory for the resulting files.
extensionExtension for the output files.
toc_fileThe file name of the table of contents, should always be valid, even when table of contents are output directly in the document.
inline_contentsA reference on a hash containing two key, one for each type of table of contents:
contentsThe associated value is a reference on an array containg the line resulting from formatting the table of contents, including a heading and a reference.
shortcontentsThe associated value is a reference on an array containg the line resulting from formatting the short table of contents, including a heading and a reference.
todayThe date. May be overriden by $DATE.
css_import_linesreference on an array containing the @import lines of 
CSS files.
css_linesreference on an array containing the normal lines of CSS files.
Flags defined by @set may be accessed through the 
%main::value
 hash. The key is the flag name, the value is the
flag value at the end of the document. 
The following array references or arrays holds formatted lines:
$Texi2HTML::THIS_SECTION
Lines of the current element.
$Texi2HTML::OVERVIEW
Lines of short table of contents. See section Special pages formatting.
$Texi2HTML::TOC_LINES
Lines of table of contents. See section Special pages formatting.
$Texi2HTML::TITLEPAGE
The title page formatted. See section Formatting of title page.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
The usefull function is a function used to print an array of lines, which also counts the number of words in the array, if needed.
$filehandle is the opened filehandle the function should write to.
\@lines_array is the array line the function should write to the file.
If this argument is omitted, the function uses $Texi2HTML::THIS_SECTION
.
$words_number is the number of words in the array, only defined if
split at nodes and $WORDS_IN_PAGE
 is defined.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
After the texinfo file has been parsed, some information is available
which can be used to modify some variables and prepare the outputting.
For example the document language, the document encoding, 
values set with @set or @setfilename and other similar 
@-commands are not known before the texinfo parsing. 
The following function reference may be redefined to be called after texinfo processing and before document generation:
This function perform the initialization of variables and any other task before document outputting.
In the default case the $BODYTEXT
 (see section Customizing the page header) 
and the hashes %NAVIGATION_TEXT
,
%BUTTONS_NAME
  (see section Specifying the buttons formatting),   
%BUTTONS_GOTO
 (see section Formatting of about text) are initialized.
Indeed the initialization of these variables is dependent upon 
the document language selection. Similarly the encoding variables are set
based on the information now available (see section Setting the encodings).
To perform the default initializations and also add more code, you could do as in the following example (save the default function reference and call it in your own function) :
my $default_init_out = $init_out;
$init_out = \&makeinfo_like_init_out;
sub makeinfo_like_init_out() 
{
   &$default_init_out();
   $NAVIGATION_TEXT{'Following'} = ' > ';
}
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
If you want to do some cleaning after the document was generated (close files, write at the end of files and so on), the following function reference may be redefined:
This function is called after the document generation.
The default is to do nothing.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
texi2html css linesIf the variable $CSS_LINES
 is set it is used for the css
entries.  For example if you don’t want any css entries, set
$CSS_LINES = '';
If this variable is undef (as in th edefault case),
it is possible to modify the texi2html css lines by modifying
the entries or adding to the %css_map
 hash. Each key is a css
selector, the corresponding value is a style string.
Another possiblility is to modify the array corresponding with the array 
reference $Texi2HTML::THISDOC{'css_import_lines'} that contains the
@import lines of CSS files, and similarly it is possible
to modify the array corresponding with the array 
reference $Texi2HTML::THISDOC{'css_lines'}  that contains 
the normal CSS files lines (for details on what corresponds with
those different lines, see HTML CSS in GNU Texinfo).
The right place to modify these arrays is in a function appearing in 
the @command_handler_process array 
(see section Bypassing normal formatting). Later, the CSS lines
are allready expanded, by the function reference below. 
In th edefault case, the resulting css lines are in $Texi2html::THISDOC{'CSS_LINES'}
. 
It is also possible to change completely the way $Texi2html::THISDOC{'CSS_LINES'} are
generated by redefining the following function reference:
This function should be used to construct the variable 
$Texi2html::THISDOC{'CSS_LINES'}.
\@import_lines are the @import lines of the 
files specified with ‘--include-css’
, 
and \@rule_lines are the css commands lines of these files.
See section Customizing the HTML and text style.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
It is possible to add lines to the text within the <head> 
HTML elements, by defining the variable $EXTRA_HEAD
.
Similarly it is possible to add text just after the <body> 
element with the variable $AFTER_BODY_OPEN
.
These variables are empty by default.
The HTML encoding of the resulting document is defined by
$ENCODING_NAME
. If the variable isn’t defined,
the @documentencoding value is used, or the 
$OUT_ENCODING
 value, if set. $ENCODING_NAME may
influence the value of $OUT_ENCODING, which corresponds with
the encoding used when writing to the resulting files.
See section Setting the encodings.
The description of the document may be specified in 
$DOCUMENT_DESCRIPTION
. 
If this variable is undef, the text 
associated with @documentdescription is used, and if there isn’t 
such test a default description is constructed using the document title and 
the name of the first section of the file.
The value used during document formatting
is $Texi2HTML::THISDOC{'DOCUMENT_DESCRIPTION'}
. 
The <body> element attributes may be set by defining the
variable $BODYTEXT
.  The resulting attributes are 
in $Texi2HTML::THISDOC{'BODYTEXT'}
.
If you want to define that variable
dynamically, you should use the init_out function reference
(see section Preparing the output).
<link> element are used in the header if $USE_LINKS
is set. @LINKS_BUTTONS
 determines which links are used.
%BUTTONS_REL
 determines the link type associated with the
rel attribute.
The default functions call the function associated with 
$print_head_navigation
 to format the navigation panel for the 
page header. Thus you can control parts of the formatting by
redefining the function reference.
$filehandle is the opened filehandle the function should write to. \@buttons is an array reference which should hold the specification of the buttons for the navigation panel.
If you want even more control, you can have full control over the page header 
formatting by redefining three function references. The function associated
with $print_page_head
 is called for all the pages, and after that,
the function associated with $print_chapter_header
 is called
if the document is split at chapters, or the function associated with
$print_section_header
 is called if the document is split at sections.
$filehandle is the opened filehandle the function should write to.
This function should print the page head, including the <body>
element.
$filehandle is the opened filehandle the function should write to.
This function is called if the document is split at chapters, after 
print_page_head.
$filehandle is the opened filehandle the function should write to.
This function is called if the document is split at sections, after 
print_page_head.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
The functions associated with the following function references are used for the formatting of sections:
$filehandle is the opened filehandle the function should write to. $first_in_page is true if this section is the first section in the page. $previous_is_top is true if this section is the section following the Top section. This function should print the current section contents.
$filehandle is the opened filehandle the function should write to. $last_element_or_before_top is true if this section precedes the top element or is the last one in page, or before the special elements.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
It is possible to add text just before the </body> 
element with the variable $PRE_BODY_CLOSE
. Nothing is added
by default.
A date is collected to be output in the footer. You can change it by 
defining $DATE
 in the initialization file.
The default functions call the function associated with 
$print_foot_navigation
 to format the navigation panel for the 
page footer. Thus you can control parts of the formatting by
redefining the function reference.
$filehandle is the opened filehandle the function should write to. \@buttons is an array reference which should hold the specification of the buttons for the navigation panel.
If you want even more control, you can have more control over the page footer 
formatting by redefining three function references.
The function associated with $print_chapter_footer
 is called
if the document is split at chapters, or the function associated with
$print_section_footer
 is called if the document is split at sections.
 After that the function associated
with $print_page_foot
 is called.
$filehandle is the opened filehandle the function should write to.
This function should print the page foot, including the </body>
element.
$filehandle is the opened filehandle the function should write to.
This function is called if the document is split at chapters, before 
print_page_foot.
$filehandle is the opened filehandle the function should write to.
This function is called if the document is split at sections, before
print_page_foot.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
For the special elements, two things must be formatted: the content and the page layout
| 6.11.1 Customizing the content of the special pages | ||
| 6.11.2 Customizing the layout of the special pages | 
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
The label for the special elements, except for the Top element
is formatted according to the function reference $misc_element_label
:
$identifier is the identifier associated with the special element. $page_name is the special element name. It should return a label that can be used for references to the special element.
| 6.11.1.1 Top element text formatting | ||
| 6.11.1.2 Table of contents and Short table of contents | ||
| 6.11.1.3 Formatting of footnotes text | ||
| 6.11.1.4 Formatting of about text | ||
| 6.11.1.5 Formatting of title page | 
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
The top element formatting is controlled by three function which also controls the layout of the top element page or section. The associated function references are:
$filehandle is the opened filehandle the function should write to. $begin_page is true if the element is the first in a page. This function should begin the Top element. At the time this function is called the top element text hasn’t been parsed.
$filehandle is the opened filehandle the function should write to.
$has_top_heading is true if there is a @heading command or
@titlefont command appearing in the Top element text.
This function should be used to format the Top element text and navigation
panel.
$filehandle is the opened filehandle the function should write to. $end_page is true if the element is the last in a page. This function should end the Top element.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
Two possibilities exist for the formatting of table of contents (and 
short table of contents). In the default case, the table of contents 
are in separate elements, at the end of the document if the document 
is unsplit or in separate files. This is consistent with makeinfo
where menus are used for navigation. Another mode may be selected by
setting $INLINE_CONTENTS
. In that case the table of contents
are not output as separate elements but 
are instead output where the corresponding @-command, 
for example @contents,
is set. This behaviour is more consistent with texi2dvi. 
If @setcontentsaftertitlepage appears in the document,
and even if $INLINE_CONTENTS is set, the table of contents are 
merged in the title (which isn’t output in the default case, see 
Formatting of title page).
Several variables may be used to control the formatting of table of contents and short table of contents:
$CONTENTS
If the variable is true a table of contents is done even if there is no
@contents command. 
If it is defined and false, no table of contents 
is done even if there is a @contents command.
$SHORTCONTENTS
If the variable is true a short table of contents is done even if there is no
@summarycontents command.
If it is defined and false, no short table of contents 
is done even if there is a @summarycontents command.
$BEFORE_OVERVIEW
The variable value is inserted before the short table of contents text.
$AFTER_OVERVIEW
The variable value is inserted after the short table of contents text.
$BEFORE_TOC_LINES
The variable value is inserted before the table of contents text.
$AFTER_TOC_LINES
The variable value is inserted after the table of contents text.
$NO_BULLET_LIST_STYLE
This should contain a css style used for the list style when there is no bullet.
$NO_BULLET_LIST_CLASS
This should contain the class assocciated with the $NO_BULLET_LIST_STYLE css style.
$NO_BULLET_LIST_ATTRIBUTE
This should contain an attribute text used for the list element when there is no bullet. For example it is used in the tables of if they are formatted with a list.
More control on the table of contents and short table of contents formatting may be achieved by redefining a function with the following associated function reference:
\@elements is an array reference contining informations about all the elements of the document. Each of the entry of this array is an hash reference which entries correspond with different informations about the element. Interesting keys have the following meaning:
toptrue if the element is the top element,
index_pagetrue if the element is an index page added because of index splitting,
toc_levellevel of the element in the table of content. Highest level is 1 for the top element and for chapters, appendix and so on, 2 for section, unnumberedsec and so on...
tocidlabel used for reference linking to the element in table of contents,
filethe file containing the element, usefull to do href to that file in case the document is split,
texttext of the element, with section number,
nametext of the element, without section number.
This function doesn’t return anything but should fill the array corresponding
with the 
$Texi2HTML::TOC_LINES
 and
$Texi2HTML::OVERVIEW
 references with the table of contents and short 
table of contents.
Another function reference is used to add a heading and a reference, to
be used with $INLINE_CONTENTS or merged in the title. Its output
is not used when the table of contents are separate elements.
This function reference returns a reference on an array holding 
the lines containing the contents, heading and reference.
$filehandle is a reference on the currently opened file if
the function is called because a @contents or
@shortcontents command was encountered, it is undef otherwise.
$command is either ‘contents’ or  ‘shortcontents’.
$element is a hash reference containing informations about the
table of contents context. Relevant keys are:
targetThe identifier associated with the table of contents, used for example to do references to the table of contents using href in HTML.
idThe identifier associated with the element, used to do labels. In 
general the same than the target, but not necessarily.
fileThe file name containing the table of contents.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
The footnotes text is allready formatting when @footnote commands
are expanded. See section Customizing the footnotes formatting.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
The default about element contains an explaination of the buttons used
in the document (@SECTION_BUTTONS, Specifying the buttons formatting) and 
an example locating the buttons targets in an example.
The formatting of this text may be influenced by the following 
hashes and variables:
$PRE_ABOUT$AFTER_ABOUTThis variable may be a scalar or a function reference. If it is a scalar, the value is used. If this is a function reference it is expanded and the returned text is used. The text is added before or after the main about text.
%BUTTONS_GOTOThe keys of this hash are element labels (see Element labels). The value
is the text associated with the element label in the about text.
The element of the hash are defined 
dynamically, you should in the init_out function reference
(see section Preparing the output).
%BUTTONS_EXAMPLEThe keys of this hash are element labels (see Element labels). The value is the text associated with the element label in the about example, typically a section number.
If this is not enough and you want to control exactly the formatting of the about text, you can redefine the function associated with the following function reference:
This function should return the about text.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
The title page is first formatted using the text appearing in 
the @titlepage section, and put in $Texi2HTML::TITLEPAGE
.
More formatting can be done using the following
function reference:
This function should complete $Texi2HTML::TITLEPAGE.
In the default case, in this function the title is output if 
there is no titlepage, the table of contents and short
table of contents are also added if they are to be output and 
@setcontentsaftertitlepage
or @setshortcontentsaftertitlepage appear in the document
(see section Table of contents and Short table of contents).
In the default case the resulting title page output is not used in the document, except if the top node is not associated with any content.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
The formatting of each of the special pages, or section in case the document is not split, is controlled by a function. The associated function reference is called accordingly:
print_Top
print_Top_header
print_Top_footer
Formatting of top element page or section. It is also used for the formatting of the top element text (see section Top element text formatting).
print_Toc
Formatting of table of contents page or section
print_Overview
Formatting of short table of contents page or section
print_About
Formatting of about (help) page or section
print_Footnotes
Formatting of footnotes section or page in case footnotes are on a separated page or the document isn’t split.
In the default case, $print_Top
 calls $print_Top_header
 for
the header and $print_Top_footer
 for the footer of top element.
All the other function call $print_misc
 which in turn calls
$print_misc_header
 for the headers and  $print_misc_footer
for the footers.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
It is possible to specify the file names with more control than with the
command line options (see section Setting output file and directory names). 
First the extension may be overrided by the variable $EXTENSION
value. The variable should be undef if no extension is
to be added.
Two function references enable 
further customization. One is usefull in case $NODE_FILES
 is true
and it is used to customize the node file name. 
\%node is a hash reference with the following interesting keys (there are much more keys):
texiThe texinfo node name.
with_sectionTrue if associated with a section.
The result is the node file name $node_file.
The other is used to customize the file names associated with each element, and the name of the file associated with the special elements.
\%element is undefined for the special elements (about, overview, table of contents, footnotes). Otherwise it is a hash reference with the following interesting keys (there are much more keys):
texiThe texinfo element name.
numberThe number associated with a section.
doc_nrA number incremented whenever a new file should begin, based on how the document is split (see section Specifying where to split the generated document).
textThe element text.
nameThe element text without section number.
$type is empty for normal elements. For the top element it is ‘top’, for the table of contents it is ‘toc’, for the overview it is ‘stoc’, for the footnotes it is ‘foot’ and for about is ‘about’. If frames are used (see section Page layout related command line options), the function reference is also called for ‘frame’, the frame file name, and ‘toc_frame’ the table of content frame file name. $docu_name is the basename of the texinfo manual. The result is the element or special element file name.
Similarly target and id may be set. The id is placed where the item is located, the target is used to construct references to that item. In general they should be equal, but not always, for example in the default case, the target for a section is the node id. The following function reference, is for target items (nodes, anchors, floats):
\%node is the same as in the node_file_name function reference
above.
$default_target is the target already set (it is also 
in $node->{'target'}), and $default_id is similarly
the id already set.
For element associated with files (which may be nodes), the function reference is:
the \%element is the same than in element_file_name, and
$default_target and $default_id are the target and id already set.
Placed items (floats, footnotes, index entries, anchors, contents, shortcontents and headings) file and target may also be set. In the default case, they should be rightly set, so be careful when changing them. The following function reference can be used:
\%placed_item is a hash reference describing the placed item,
in the same vein than above.
the \%element is the same than in element_file_name, 
corresponding with the element containing the placed item.
$default_file, default_id and
$default_target are the file, id and target already set.
$context describes the context, it is empty in the normal cases, 
and can also be set to ‘footnotes’ if in footnotes, or to
‘no_associated_element’ if the placed item is out of any element
(typically in @titlepage, @copying).
For special elements, the %misc_pages_targets
 hash is 
used to set the target and id. The possibilities for the keys 
are ‘Overview’,
‘Contents’, ‘Footnotes’ and ‘About’.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
Within the document, @printindex commands are expanded as explained
in Customizing the formatting of index lists. In case you want to do something special with index 
entries, outside of the document, you should first set the variable
$IDX_SUMMARY
 true. After that some function reference will be called
for each non empty index. For each index there are 3 function 
references, one called for initialization, one called for each index entry
and the last one called for finalization.
$index_name is the two letters name for the index. 
This function
is called for each index 
appearing in the document, before 
index_summary_file_entry.
$is_printed is true if there is a @printindex for that index.
$manual_name is the manual basename.
This function is called for each entry of an index. index_name is the
name of the index. $entry_text is the entry in plain text,
$formatted_entry is the index entry formatted, $texi_entry is the
entry with texinfo commands. $entry_reference is the reference placed 
at the index entry place, in the form ‘file#id’.
$entry_element_header is the formatted header of the element containing 
the index entry. entry_element_header is the reference to the
beginning of the element containing the index entry, in the form
‘file#id’. 
$is_printed is true if there is a @printindex for that index.
$manual_name is the manual basename.
$index_name is the two letters name for the index. This function
is called for each index appearing in the document, after
index_summary_file_entry.
$is_printed is true if there is a @printindex for that index.
$manual_name is the manual basename.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
Some simple customization may be achieved with the redefinition of the variables associated with the command line options. For the description and an explanation of the meaning of these variables, Customizing the HTML and text style.
Other variables and hash entries can be modified in initialization file to achieve more customization. Lastly, functions references corresponding with functions called from the main program and initialization files may be redefined.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
There are three contexts of interest, one is the normal context, the other
is a special context, called the preformatted context and the last is
the string context. The preformatted
context occurs when the spacing between words is kept. This is the
case, for example, in @display or @example regions, and in 
menu comments (see section Menu formatting). The preformatted regions are usually
rendered in <pre> elements in HTML.
The string context occurs when rendering strings without formatting elements,
in comments or titles for example.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
There are three passes in texi2html. During 
pass 0, the @macro are 
expanded, in pass 1 the document structure is gathered and in pass 2
the result is output. In most cases you shouldn’t care about
it, as almost all of the output customization is done in pass 2.
Only if you want to do something before the pass 2 should you care.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
This includes the commands whose name is a nonletter character like @@, 
the commands with lettered characters and braces
but whose braces should be empty, like @TeX{}, or some commands
associated with accentted letters like @AA{}. If there happens to
be something within the braces, it is put after the command, thus
@TeX{something}
leads to the same than
@TeX{} something
Each of these categories of commands have three associated hashes, one for normal context, the other for preformatted context and the last in strings. The keys of the hashes are the command names, the associated value is the text replacing the command.
The hashes are:
| command type | normal text | preformatted text | string | 
| one nonlettered character | %simple_map | %simple_map_pre | %simple_map_texi | 
| nothing in braces | %things_map | %pre_map | %texi_map | 
To change the HTML resulting from these constructs, just change the
value. For example, if you want ­ to be outputted for @-
in normal and preformatted context, write in your init file:
$simple_map{'-'} = '­';
$simple_map_pre{'-'} = '­';
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
The formatting of a punctuation character followed by  is determined
by the hash %colon_command_punctuation_characters
. If a 
command is preceded by a character in th is hash, it is replaced by the 
associated value. In the default case, the associated value is also the 
character, so this leave the punctuation character unmodified.
The following function reference may be redefined to handle characters
that are in %colon_command_punctuation_characters:
The $character is a character appearing in 
%colon_command_punctuation_characters and preceding a  
command. In the default case the associated value in
%colon_command_punctuation_characters is returned.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
The formatting of the HTML produced by style and indicatric 
commands (@tt, @code, 
@email, @titlefont), the accentuation related
commands taking argument (@', @udotaccent, @dotless)
and miscalleneous commands (@email, @verb, @w, 
@uref, @math, @asis) is controlled by two hash in the
default case, 
%style_map
 for normal context, %style_map_pre
 for
preformatted context and %style_map_texi
 in string context. 
The key of the hashes are the command names. There are two possibilities for the values corresponding with two interfaces. The values may be strings or hash references, and you can chose the interface depending on the one you prefer. The interface with hash reference is a bit more flexible but might also be regarded as more complex. If you don’t like either of these interfaces you can define your own.
Some remarks are in order:
@`a) should be keys of the
hash %accent_map
 hash, even if no value is associated.
@math is handled differently if LaTeX2HTML is used.
| 7.5.1 An interface for commands formatting with a hash reference | ||
| 7.5.2 Defining the style and indicatric commands interface | 
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
The key of the hashes are the command names. The value determine how the command argument is formatted. This value is a reference on a hash. In this hash each key corresponds with a type of information for the formatting, and the value is the corresponding information. For example, in
$style_map{'command'} = { 'args' => ['code'], 'inline_attribute' => 'code'};
the arguments for @command are interpreted as specified by 
the values associated with the ‘args’ key while the inline_attribute 
associated 
with that command is ‘code’.
The following keys in the hashes associated with each command have the following meaning:
The value associated is a reference on an array. Each element of the array defines how the arguments (separated by ‘,’ in the texinfo code) for the @-command should be formatted. The possibilities are
normalfor normal text,
codefor text with ‘---’, ‘--’, ‘''’ and ‘``’ kept as is,
keepif the texinfo should be kept as is, without interpretation of the @-commands.
For example, we have
$style_map{'email'}->{'args'} = ['code', 'normal'];
because ‘---’, ‘--’, ‘''’ and  ‘``’ should be kept as is in
the first argument of @email.
The default is ‘['normal']’.
If the associated value is a word, it is considered to be an XML 
element name, and the argument is enclosed between the element opening
and the element closing. For example, if the value is elem, the
resulting HTML is <elem>arg</elem>.
If the text is a word followed by some text,
the word and is interpreted as above, and the
text is considered to be the attributes text of the element. 
Thus elem class="elem" leads to 
<elem class="elem">arg</elem>.
This works only if there is only one argument. 
Like an attribute, except that it is closed at each paragraph end and reopened at each beginning of paragraph. This is in fact more used than ‘attribute’ since it allows to have well formed HTML/XML.
The associated value is added in front of the text and each time a paragraph is restarted while within the command.
The associated value is added after the text and each time a paragraph is ended while within the command.
The associated value is added in front of the text.
The associated value is added after the text.
If the corresponding value is true, the result is 
enclosed in quotes $OPEN_QUOTE_SYMBOL
 and 
$CLOSE_QUOTE_SYMBOL
, with defaults 
‘`’ and ‘'’. 
The corresponding value should be a function reference. The corresponding function is called with the following arguments:
$commandThe @-command name
$argsA reference on an array containing the arguments of the @-command.
$command_stackA reference on an array containing the name of the @-commands containing the @-command being formatted, latest on top.
$stateA reference on a hash containing a lot of informations about the context of the @-command.
$line_nrAn opaque structure containing the information about the line number of the 
@-command. It can be used to call main::line_error or
main::line_warn with first argument a message, and second argument 
$line_nr. 
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
If you don’t like this scheme, it is possible to change how those commands are processed by redefining the following function reference:
$command is the @-command, $style is the value associated with 
the $command in the %style_map, %style_map_pre 
or %style_map_texi hashes.
The $text is the text appearing within the @-command braces.
args is a reference on an array contening the command arguments 
formatted according to the same conventions than with the reference hash style
(provided the value associated with the @-command is a hash reference with a
$arg key as described in Reference hash args).
If $text is split in paragraphs each paragraph is passed through
the function, and $no_close is true if it is not the last paragraph,
while $no_open is true if it is not the first paragraph.
$line_nr
is an opaque structure containing the information about the line number of the 
@-command. It can be used to call main::echo_error or
main::echo_warning with first argument a message, and second argument 
$line_nr.
$state
is a reference on a hash containing a lot of informations about the context
of the @-command.
$command_stack
is a reference on an array containing the name of the @-commands containing 
the @-command being formatted.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
The formatting of special simple commands is controlled by functions. To customize the output, the corresponding function references should be redefined. All these functions return a formatted text.
The formatting of anchors is controlled by $anchor_label
.
$identifier is the anchor identifier, $anchoris the @anchor
argument.
In the default case, it uses a function reference,  $anchor
that can do a reference target or link. It is especially relevant for HTML but can be used in other formats, it is a rather common element of different formats.
If $identifier is not empty, this value should be used to create
a target for links (typically associated with a name or id 
attribute in HTML).
The $href argument specifies a hpertextual reference which should be
used to link to a target.
In case both $identifier and  $href are given the text produced
should be both a target for $identifier and a link to $href.
$text is the text to be displayed. 
$attributes are additional attributes.
It should be reasonable to assume that the attributes are for a <a>
HTML element. 
To customize the images produced by @image, the first possibility 
is to modify the @IMAGE_EXTENSIONS
, which holds a list of 
filename extensions for image files. It is also possible to redefine
the function used to determine the filename of the image:
Warning: This description is wrong. The API is still moving, so don’t count on it.
$basename is the first @image argument, $extension
is the corresponding @image argument. This function reference 
should return an array of image filenames without path that the main 
program should look for.
Last, it is possible to control 
the formatting of @image by redefining:
$file_path is the image file name with the path from the output directory
to the source manual directory prepended, $basename  
the file name without extension (the first @image argument). 
$preformatted is true if the image 
appears in preformatted text. $file_name is the file name without path 
but with extension. $alt_text is the alternate text, it may be 
undefined. $width and $height are the corresponding arguments 
of @image, $raw_alt is the unmodified alt argument of 
@image and $extension holds the corresponding 
@image argument.
$working_dir is the path to working dir relative to the output
directory. $file_relative_path is the file name relative to the 
$working_dir.
The formatting of @sp is controlled by:
$number is the numeric argument of @sp.
$preformatted is true if the @sp appears in preformatted text.
The formatting of @acronym and @abbr is controlled by:
$acronym_texi is the acronym argument with texinfo @-commands, $acronym_text is formatted.
The other arguments are related with
the explanation, the second arg of the acronym. $with_explanation is 
true if the second argument of the acronym command is present. If an
explanation exists, coming from previous @acronym or as an arg of 
this command, the other args are defined: \@explanation_lines is a 
reference on an array containing the simply fomatted explanation lines, 
$explanation_text is the explanation text formatted,
$explanation_simply_formatted is the explanation with a light 
formatting, unabling in HTML (or XML) the explanation 
to be in an attribute.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
Some characters are processed especially in text: ‘---’, ‘--’,
‘``’ and ‘''’. This is done only if in normal text and not in 
some commands (@code, @env…). A function reference
is called to process the text and should take care of those constructs.
It may also be used to transform the text, for example set it in upper
case if it is in @sc. This function should also take care
of protecting special characters
The function processes $text and returns $processed_text. 
The other arguments give some information about the context of the text.
$in_raw_text is true if the text appears in special place where
there is no formatting, typically in comments. $in_preformatted
is true if in a preformatted environemnt, and $in_code is true
if in a special command like @code, @env where
‘---’, ‘--’, ‘``’ and ‘''’ should not be
touched. $in_math is true if in @math.
$in_simple is true if in string context.
 $command_stack is an array containing the name of the 
formatting @-command that enclose the text.  
In the default case the ‘---’, ‘--’, ‘``’ and ‘''’
constructs are expanded if needed and the text is upper-cased if in 
@sc. Special characters (‘&’, ‘"’,
‘<’ and ‘>’ in HTML) are protected if needed. 
Some characters are special, for example we have ‘&’, ‘"’, ‘<’ and ‘>’ in HTML. In some cases some pieces of text don’t go through the above function, but still needs to be protected to appear in text. This is done by the function associated with the function reference
The function processes the unprotected text $text and returns the resulting protected text $protected_text.
Empty lines are processed by the following function reference, which could be usefull if empty lines are to be removed for example
This function processes an $empty_line and returns the resulting text $resulting_text. $state is a structure that holds informations about the state of the parsing. Empty lines are left as is by default except right after a definition @-command.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
@-commands that appear on a line and take the line as argument may
be formatted especially, if they are in the %line_command_map
.
In that case the following function reference is used to format the
@-command:
$command is the @-command. $arg_text is the @-command formatted argument, $arg_texi is the @-command argument without any formatting. $state is a structure that holds informations about the state of the parsing. The resulting text is $resulting_text.
In the default case, @-commands appearing in @titlepage, 
@title, @subtitle, @author are formatted
by this function.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
texi2htmltexi2html writes some strings in the generated document at
various places, at the page footers, on the help page, for special 
section headings, buttons alt text and so on. These strings are
customizable. The string chosen depends on the language of the
document (set by ‘--document-language’
, $DOCUMENTLANGUAGE
 or 
@documentlanguage). This is the basis for internationalization
as it allows for strings translations.
The Gettext framework is used for those strings. libintl-perl is used as a gettext implementation, and more precisely the pure perl implementation is used, to be sure to have a consistent gettext-like implementation which is not the case if the system one is used. libintl-perl is shipped in texi2html and installed to be sure that it is available. It is also possible to use the system libintl (currently decided at build-time).
The texi2html_document domain is used for those strings. These strings are texinfo strings, which may have @-commands, and the variable parts of the strings are denoted by ‘{arg_name}’ as is common practice for perl gettext. For more on internationalization, see Internationalization.
| 7.9.1 Old style translations | 
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
A gettext-like framework appeared in version 5.0.
For reference the previous handling of strings (up to 1.82) 
is still documented here.
With that system, the strings are found in 
a hash reference, $LANGUAGES
. 
Each key is a language code. The associated value is also a hash
reference. The key is an english string and the associated value
is the string replacing the english string, if present. For example,
we have
$LANGUAGES->{'fr'} = {
              ' Up ' => 'Plus haut',
};
It means that whenever the string ‘ Up ’ is to be written and the language is ‘fr’, ‘Plus haut’ is written. It is possible to customize the english strings by redefining the ‘en’ language hash.
When a string contains a substring like ‘{’ name ‘}’
it means that the string will be expanded by texi2html. For
example, if we have
$LANGUAGES->{'fr'} = {
              'See {node_file_href}' => 'Voir {node_file_href}',
};
‘{node_file_href}’ will be expanded to an href for a node in a 
file by texi2html in the string. 
When a @documentlanguage appears in the document and the language
wasn’t set on the command line, it may be convenient for the user to
redefine some variables based on the new language. There is a function 
reference that may be used for that, it is called each time  a 
@documentlanguage is encountered:
This function is called each time @documentlanguage is encountered
and the language wasn’t set on the command line. It should be used
to retranslate some strings based on the new language.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
| 7.10.1 Reference to external manual | ||
| 7.10.2 Reference to an internal node | 
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
The references are produced with two function references, one for the hypertextual reference construction, the other for the full reference to external manual.
$node is the node name, with @-commands. $node_identifer is the node name mapped to an identifier acceptable as a file name. $xml_node_identifier is the node name mapped to an identifier acceptable as an XML identifier. Those identifiers are built as explained in HTML Xref in GNU Texinfo, thus allowing for cross references to external manuals. $file is the manual or file name of the external reference. This function should return an href leading to the external manual.
The default for this function is to make a reference compatible with 
makeinfo  (see HTML Xref in GNU Texinfo).
This function formats a reference to an external texinfo manual.
The $command is the ref command (ref, xref or 
pxref, in text, at sentence beginning or in parenthesis).
The optionnal $section argument is the section in the book and 
 book is the book title.
$node_and_file is manual file name. $href it an hypertextual
reference to the distant manual constructed using the above function. 
$cross_ref_name is an optionnal cross
reference name appearing in the reference command. 
\@args_texi is a reference on an array containing the @-command
arguments, not formatted, with \@formatted_args contains the formatted
@-command arguments. $node is the node name, formatted.
This function returns
the text corresponding with the external html manual reference.
This function returns the full formatted text of the external reference.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
A function reference is available for internal references.
This function formats a reference to a node in the current manual.
The $command is the ref command (ref, xref or 
pxref, in text, at sentence beginning or in parenthesis).
$href it an hypertextual reference linking to the corresponding
node or section. $short_name and $name hold the text for the 
reference but $short_name can be the node name which is assumed to 
be shorter than the section name.
$is_section is a boolean true if the reference is a reference to a 
section. 
\@args_texi is a reference on an array containing the @-command
arguments, not formatted, with \@formatted_args contains the formatted
@-command arguments.
This function returns the full formatted text of the internal 
reference.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
When a command controlling the alignement of text is used (@center,
@flushleft and @flushright), the main program takes
care of opening and closing paragraphs. The alignement commands are the
key of the %paragraph_style
 hash. 
The value is used in the function doing the formatting of the paragraphs. 
See section Formatting (or not) a paragraph and a preformatted region.
A function references allows for a customization of the formatting of the text appearing in the command block.
$command is the command name, $text is the text appearing within the command. This function returns a formatted text. The default is to return the text unmodified.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
| 7.12.1 Paragraph and preformatted region formatting | ||
| 7.12.2 Avoiding paragraphs in formats | 
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
The formatting of a paragraph region or a preformatted region, is controlled by function references:
This function formats a paragraph. $text is the text of the paragraph, $alignement is the empty string when no alignement command has been seen, otherwise it is the current alignement command name. See section Commands used for centering and flushing of text. $indent holds ‘noindent’ or ‘indent’ if the corresponding @-command appeared in the paragraph. $command_stack_at_end and $command_stack_at_begin are arrays containing the opened @-commands at end and at beginning of the paragraph, latest on top.
The remaining arguments are usefull when the paragraph appears within a
list or table. It is usefull whenever the paragraph has to be formatted
differently when appearing in such environments. 
Moreover in that case the format command (@itemize…) 
may have
an associated formatting command.
$formatting_command is this  formatting command
(like @minus).
$formatting_command_formatted is the command formatted in html
in case the formatting command is a leading command (like @minus)
which should be leading the first paragraph.
\$paragraph_number is a reference on the number of
paragraphs in that format command. The corresponding variable should be 
increased when a paragraph is added. $format is the format command. 
See section Formatting individual table and list items.
If the $format is an enumerate, $item_number is the number of the item in the list, $enumerate_style is the argument of the enumerate, $number is the number or letter corresponding with this item.
This function formats a preformatted region. $text is the text of the
preformatted region, $style is the css style associated with that
preformatted region (see section Customizing the texi2html css lines). $region_name is the 
name of the command opening        
the preformatted region (example…, see Formatting of complex formats (@example, @display…)) 
or a identifier for the preformatted context (for example 
menu-comment, see Menu formatting).
The alignment commands are not taken into account, as the spaces are
preserved in preformatted regions, you should flush and center by hand.
$command_stack_at_end and $command_stack_at_begin are arrays
containing the opened @-commands at end and at beginning of the preformatted
region, latest on top.
The remaining arguments are usefull when the preformatted region appears 
within a list or table. It is usefull whenever the preformatted region 
has to be formatted
differently when appearing in such environments. 
Moreover in that case the format command (@itemize…) 
may have
an associated formatting command.
$formatting_command is this  formatting command
(like @minus).
$formatting_command_formatted is the command formatted in html
in case the formatting command is a leading command (like @minus)
which should be leading the first preformatted region.
\$preformatted_number is a reference on the number of
preformatted regions in that format command. The corresponding variable 
should be increased when a preformatted region is added. $format is the 
format command. 
See section Formatting individual table and list items.
If the $format is an enumerate, $item_number is the number of the item in the list, $enumerate_style is the argument of the enumerate, $number is the number or letter corresponding with this item.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
It is possible to avoid that a format closes the previous paragraph or
preformatted region and reopens one, by putting the format command in a 
hash, %format_in_paragraph
 with a true value. This only 
makes sense for few commands since otherwise the nesting of formats and
paragraphs could become wrong.
If the value of %no_paragraph_commands
 associated with a command is
true, no paragraph is started by the command if outside of a paragraph
(after an empty line, for example). If the value is set to 0, it will start
a paragraph. If the value is not set, reasonable defaults are
set.
It is also possible to stop a paragraph when an @-command happens by
putting the @-command in the %stop_paragraph_command
 hash
associated with a true value.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
@example, @display…)Here we see how a whole complex format is formatted. For the formatting of the text, see Formatting (or not) a paragraph and a preformatted region.
The formatting of the complex formats is ultimately controlled by a
function, however the default for this function uses a hash and 
changing the hash values should be enough in most cases. This
hash is called %complex_format_map
. It has a key for each
of the complex format commands (example, smallexample, 
lisp, smalllisp, display, smalldisplay, 
format, smallformat).
The associated value is a reference on a hash. The keys are:
beginThe begin should lead to the beginning of the
formatted HTML.
endThe end should lead to the end of the 
formatted HTML.
classThe HTML class. If not defined, the command name.
pre_styleThe preformatted style. If not defined the corresponding CSS style is used.
styleIf the associated value is code, the format is assumed to be in 
code style, where 
with ‘---’, ‘--’, ‘''’ and  ‘``’ kept as is.
If the key is absent the format  inherits the code style
and the font from the enclosing context.
The enclosed text will be formatted as described in Formatting (or not) a paragraph and a preformatted region, and the name of the complex format will be available to the function formatting the text.
If you aren’t satisfied with this scheme, you can redefine the following function reference for a better control over the complex format formatting:
$format_name is the complex format name, $preformatted_text is the text allready formatted as described in Formatting (or not) a paragraph and a preformatted region. This function returns the whole complex format.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
The formatting of lists and tables is done at two levels:
| 7.14.1 Formatting individual table and list items | ||
| 7.14.2 Formatting of a whole table or list | 
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
In texinfo it is possible to give @itemize or table command (hereafter
called a format command) a formatting command. 
For example @minus is the formatting command here:
@table @minus
The default is to apply the command to the text item, however it is possible
to avoid it.
The hash %special_list_commands
 has an entry for each of the 
format command. Each of these entries is a hash reference. If a formatting
command is a key of the hash reference, then the formatting command is not
applied to the text item for that format command. For example, if we have:
$special_list_commands{'itemize'} = { 'bullet' => '' };
and we have the following @itemize:
@itemize @bullet @item an item @end itemize
then @bullet will not be applied to an item.
More control of the text before formatting of the line or the item is achieved with the following function reference:
The $format is the list or table @-command, 
$line is the item line, $command is the format command,
$prepended is set to the text folllowing the format command
on the format argument line.
The $number is the number of the item, as set in @enumerate.
The $result_line replaces the item argument.
$open_command is an obsolete return code that can be set to 
anything.
The items of lists are formatted using the following function reference:
This function formats the text between @item commands. $text 
is the text corresponding with the item. $format is the type of format,
‘itemize’ or ‘enumerate’. $command is the formatting command
given in argument to @itemize, $formatted_command is this command
formatted if it is a leading command, like @minus.
If the $format is an enumerate, $item_number is the number of the item in the list, $enumerate_style is the argument of the enumerate, $number is the number or letter corresponding with this item.
If the $format is an itemize, $prepended_texi is the text that appeared on the itemize line, maybe after the formatting command (if any), and $prepended_formatted is the corresponding text, formatted.
The two columns tables (@table, @ftable and @vtable), 
items are formatted using two function references,
one for the first line located on the @item line corresponding
with the first column, the other for the text appearing on the
following lines, corresponding with the second column text.
This function is used to format the text on the @item line.
$item_text is the text line. In case there is an index entry 
associated with the @item (as with @ftable and 
@vtable), $index_label_text is the text inserted at 
the place where an index entry appears. See section Formatting of index entries.
$format is the type of format,
‘table’, ‘ftable’ or ‘vtable’. $command is the formatting command
given in argument to the table format command.
$command_stack is an array with all the @-commands opened, latest
on top.
$item_command is the item command, ‘@item’ or ‘@itemx’.
$formatted_index_entry is the index entry formatted.
This function is used to format the text on the lines following
the @item line. $text is the corresponding text. 
The multitable elements formatting is controlled by the functions associated with two function references. One for a cell, and the other for a row.
This function is used to format the text of a multitable cell, the text 
following a @item or a @tab.
$text is the corresponding text. $item_command is the command 
used to introduce the row, such that it is possible to distinguish 
between @item and @headitem.
\@columnfractions is a reference on an array 
containing the @columnfraction arguments, if any, and 
\@prototype_row is a reference on an array containing the row prototypes
given on the @multitable line, if any.
\@prototype_lengths array contains the lengths of the row prototypes
formatted.
$column_number is the maximal number of columns.
This function is used to format a multitable row. $text is
the row text, with cells allready formatted with the $cell
function reference. $item_command, \@columnfractions, \@prototype_row, \@prototype_lengths and $column_number are the same than in the function reference above.
In the default case, this function is interlinked with 
$begin_format_texi (see section Customizing format opening)
and @multitable formatting
since a stack of possible nested 
multitables is kept to know the cell number.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
If the Texinfo command is a key of the %format_map
, the associated
value is used to specify the formatting of the construct, otherwise a function 
is called. 
The value in %format_map associated with a command is interpreted 
similarly with values associated with more simpler commands:
In case the %format_map isn’t used, a function reference called
$table_list
should be redefined, the associated function will be called each time
a command isn’t found in %format_map.
$format_command is the Texinfo command name, $text is the 
formatted items. $command is the format command given in argument
to the format command, $formatted_command is the same, but formatted.
$prepended_texi is the remaining text on the format command line,
$prepended_formatted is the same, but formatted.
Only relevant in @enumerate, $item_nr is the item number, and 
$enumerate_style is the @enumerate style. Only relevant in 
@multitable
\@columnfractions is a reference on an array 
containing the @columnfraction arguments, if any, 
\@prototype_row is a reference on an array containing the row prototypes
given on the @multitable line, if any,
\@prototype_lengths array contains the lengths of the row prototypes
formatted and
$column_number is the maximal number of columns.
If you still want to use %format_map
 but differently from 
the default, it is possible to redefine the following function reference:
$command is the @-command, $format is the entry associated with
$command in %format_map. $text is the formatted items.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
The formatting of definition commands is controlled by a main hash, 3 strings and another hash, and and five functions. The mainhash describes how the text on the definition line is interpreted, the functions control the formatting of the definition line and the definition function text.
| 7.15.1 Customizing the interpretation of a definition line | ||
| 7.15.2 Customization of the definition formatting | 
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
The keys of the hash %def_map
 are definition command names.
There are two types of entries:
For example if we have:
$def_map{'deftruc'} = '@defvr {A truc}';
and a line like
@deftruc var
the line will be transformed in
@defvr {A truc} var
The remaining of the array describes how to interpret the text following the definition command on the definition command line. The entry item specify what corresponds with the next bracketed item or word. Currently the possibilities are ‘category’, ‘name’, ‘type’, ‘class’, ‘arg’ and ‘argtype’. ‘arg’ means that the arguments are not mixed with type definitions, with ‘argtype’ types are mixed with definitions. When there is no ‘arg’ nor ‘argtype’ it is the same than ‘argtype’ (like makeinfo).
For example if we have
def_map{'defvr'} = [ 'v', 'category', 'name' ];
The first bracketed item following @defvr is considered
to be the category and the next one is the name. The index associated
with the definition line is the variables index.
Some characters are special with regard with definition parsing, they are delimiters, the can have a role in definition argument determination, and also hae a special meaning in arguments parsing. This is not very well documented in the texinfo manual, so it is subject to change. Strings allow to determine the delimiters:
$def_argument_separator_delimiters
Characters that separate arguments, currently ()[],.
$def_always_delimiters
Character that are always delimiters, if they appear in a type or a 
parameter,
()[].
$def_in_type_delimiters
Character that are considered as delimiters only if in a type. In a parameter they are part of the parameter.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
Five functions are used when formatting a definition command:
This function precise a category name associating a class $class (if given) with $category. The $style of the definition may be ‘f’, for function, ‘v’, for variable or ‘t’, for type. The $command is the definition @-command.
This function precise a name associating a class $class (if given) with $name. This is used to do an index enntry associated with th edefinition command. The $style of the definition may be ‘f’, for function, ‘v’, for variable or ‘t’, for type. The $command is the definition @-command.
This function formats the definition line. $class_category is the category
formatted with $definition_category
, $name, $type and 
arguments are the element of the definition line. $index_label is
the text inserted at the place where an index entry appears. 
See section Formatting of index entries.
\@arguments_array is an array holding the definition arguments, 
formatted. \@arguments_type_array holds the type of the definition
arguments, like ‘name’, ‘type’ and similar arguments, 
‘paramtype’.
‘delimiter’ and  ‘param’. \@unformatted_arguments_array 
holds the arguments without @-command substitution. $command is the
definition command, after substitution. 
$class_name is the class applied on name, formatted
as specified in definition_index_entry. $category and 
$class are the corresponding arguments. $style corresponds with the
index style, as explained above. $original_command is the unmodified
definition @-command.
This function formats the definition text, $text.
This function formats the whole definition. The definition line and text formatted by the above functions are in $text.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
A function controls the formatting of sectioning element headings, with the corresponding function reference:
The \%element_reference is a reference on a hash corresponding with the sectioning element. The following keys are of interest:
textThe heading text
text_nonumberThe heading text without section number
nodetrue if the sectioning element is a node without associated structuring command
levelThe level of the element in the document tree. ‘0’ is for @top,
‘1’ for @chapter and so on
tag_levelthe sectioning element name, with @raisesections and 
@lowersections taken into account
toptrue if it is the top element
It is also possible to customize the heading text with section number with the following function reference (called for headings and nodes):
$heading_command is the sectioning @-command of that heading. $heading is the texinfo for that heading. $number is the heading number classicaly computed with dots between numbers, and letters for top level appendix numbering. This function should return the texinfo text corresponding with the numbered heading.
The label associated with the heading that can appear before the heading itself and even before the navigation panel is customized with the following function reference:
$identifier is the identifier associated with the heading. \%element_reference is the same as above. $command is the @-command appearing on the line, and $unformatted_line is the line, unformatted.
Additionally, for @node and sectionning @-commands the formatting
of the label, navigation panel and heading is controlled by:
\%element_reference is the same as above. $command is the heading @-command. $command_texi_arg is the argument of the @-command, unformatted. $formatted_arg is is the argument of the @-command, formatted. $in_preformatted is true if in preformatted environment. $one_section is true if there is only one section. $first_in_page is true if this is the first heading in a page. $is_top is true if the heading is considered as a top element heading. $previous_is_top is true if the previous helement was a top element. $unformatted_line holds the whole line, unformatted. $element_id is the id of the heading. $new_element is true if the heading is the first of an element block.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
@verbatim, @cartouche, @quotation)Regions corresponding with raw text, like @verbatim, @html, 
@tex or the content of the file given in @verbatiminclude 
argument are formatted according to the following function reference:
$command is the command name, $text is the raw text.
In the default case, if $command is verbatiminclude 
the text is the content of the @verbatiminclude file argument.
If LaTeX2HTML is used, @tex regions are handled differently,
(see section Bypassing normal formatting).
The @cartouche command formatting is controlled by the
function reference:
$text is the text appearing within the cartouche.
The formatting of @quotation and @smallquotation 
is controlled by two function references.
The first one is usefull in case the @quotation has an argument, as
it allows to prepend a string to the quotation text:
$command is the @-command. $text is the argument of the quotation with @-commands not interpreted. This function can return a string which will be prepended to the quotation text.
The whole quotation is formatted by:
$command is the @-command.
$quotation_text is the quotation text, formatted, with the text 
prepended by the function above. $argument_text is the argument 
of the @quotation, formatted. $argument_text_texi is the argument
of the @quotation, simply formatted.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
There are two possibilities for menu formatting:
@example, @display…);
The simple formatting in a preformatted is used if 
$SIMPLE_MENU
 is true, 
otherwise the format with tables is used (this is the default).
If $USE_ACCESSKEY
 is set, the accesskey attribute 
is used in anchors. In that case the %BUTTONS_ACCESSKEY
hash is used for the access key.
To understand how the formatting of menus is controlled, the different parts of a menu are first described, then how to control the formatting of each of these parts, for each possible formatting.
| 7.18.1 The structure of a menu | A menu consists in menu entry and menu comments | |
| 7.18.2 The formatting of the different menu components | ||
| 7.18.3 Simple menu formatting in a preformatted environment | formatting of a whole menu in a simple preformatted environement | |
| 7.18.4 The formatting of the menu in a table | formatting of a whole menu in a table environment | 
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
In texi2html, a menu is considered to be composed of 2 parts, the
menu entries and the menu comments. Menu entries are further 
divided in an entry link and optionnaly an entry description.
The entry link consists in a node name and an optionnal menu entry
name.
A menu entry begins with ‘*’ at the beginning of the line. It begins with the entry link, followed by the description. The description spans until the next menu entry, or an empty line not contained within a command block which begun in the description. An empty line or starts a menu comment, which spans until the next menu entry.
Here is an illustration of these rules:
@menu
* entry name: node name.        description begins
   description continues
* another menu entry::
   description begins
                    description continues
   A menu comment, after an empty line
* node::                        description begins
still in description.
* last entry::         description begins @emph{text
of the description, even if there is an empty line,
because we are in @emph}.
@end menu
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
If in a preformatted context (and $SIMPLE_MENU isn’t set), the 
menu link and description are put in the same preformatted environment.
This can be avoided with $SEPARATE_DESCRIPTION
.
Two function references are associated with the formatting of the different parts of a menu:
$section is the section name corresponding with the link, $href
is the link hypertextual reference. $href may be absent. \%state
holds informations about the current context. 
$node is the node name, $name is the
name of the node. $ending is the text ending the link entry, 
in general ‘::’ followed by some spaces.
$has_name is true if the entry has an explicit name, otherwise
$name has been constructed using the formatted node name.
$command_stack is an array containing the commands enclosing
the menu link. It is used in the default case to detect if the 
menu link is right in the @menu or not, since if it is not 
right below the menu the formatting is simpler.
$preformatted is true if in preformatted context.
See section Three contexts for expansions: preformatted, normal and string. 
This command is not called if $SIMPLE_MENU is set.
$description_text is the text of the menu description. 
The formatted link is also here if in preformatted context and 
$SEPARATE_DESCRIPTION is not set.
\%state
should be used similarly than for the menu link. $element_text
is the heading of the element associated with the node.
$command_stack and $preformatted are the same than for the
menu link.
The menu comment part is formatted like a normal command, 
called menu_comment. It is only used if not in preformatted 
environment and if just below a @menu since otherwise one
cannot tell if it is a menu commment or normal text.
The default is to have it be formatted
like a Formatting of complex formats (@example, @display…), with
$complex_format_map{'menu_comment'} =
{
   'begin' => "<tr><th colspan=\"3\" align=\"left\" valign=\"top\">",
   'end' => "</th></tr>", 'class' => 'menu-comment',
}
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
If the menu is to be formatted in a single preformatted environment,
an entry for ‘menu’ and ‘detailmenu’ 
should be added to the %complex_format_map
hash (see section Formatting of complex formats (@example, @display…)).
In the default case, if the user didn’t add an entry himself, a very simple 
entry is used, with:
$complex_format_map->{'menu'} = { 'begin' => '' , 'end' => '',
    'class' => 'menu-preformatted' };
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
In the default case, the name of the section corresponding with the 
node is used instead of the node name. If $NODE_NAME_IN_MENU
 is 
true, however, node names are used. If $AVOID_MENU_REDUNDANCY
is true and menu entry equal menu description the description isn’t printed. This is the default. Likewise, if node or section name equal entry name, do not print entry name.
A symbol, $MENU_SYMBOL
 is put at the beginning of menu entries
when the node name is used. The default is ‘•’.
If $UNNUMBERED_SYMBOL_IN_MENU
 is true it is 
also put at the beginning of unnumbered section names. This is not
done by default.
The menu comments are considered to be preformatted text. The style 
associated with this preformatted text is determined by 
$MENU_PRE_STYLE
. Default is ‘font-family: serif’.
The entry similar with an entry in %complex_format_map 
(see section Formatting of complex formats (@example, @display…)) used when the menu appears in a preformatted
enviroment is in
$MENU_PRE_COMPLEX_FORMAT
, and, in the default case is:
$MENU_PRE_COMPLEX_FORMAT = {
              'pre_style' => $MENU_PRE_STYLE, 
              'class' => 'menu-preformatted'
   };
The css class associated with menu comments is menu-comments.
The following function reference controls the formatting of a wole menu or a detailmenu in that case:
$command is the menu command, currently ‘menu’, ‘detailmenu’ or ‘direntry’. $menu_components_text is the formatted menu components text, obtained as explained above.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
Two different things needs to be handled for indices formatting, the place
where the index term appears, the index entry, and the index list itself.
The indexing commands like @cindex determines where index entries
appear, and the index list is printed with a @printindex command. 
| 7.19.1 Formatting of index entries | Index entries in the main document are targets for hypertext references | |
| 7.19.2 Customizing the formatting of index lists | Customizing the formatting of the index list | 
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
Index entry places in the main text may be the target for hypertext references. Their formatting is controlled by the function associated with the following function reference:
$identifier should be used to create
a target for links (typically associated with a name or id 
attribute in HTML).
$preformatted is true if the index entry appeared in preformatted text.
$entry is the index entry with all the @-commands removed.
$index_name is the index name, $command is the index command which
may be a index command like @cindex, but also a definition or 
a table. $texi_entry is th eindex entry with @-commands, and 
$formatted_entry the entry formatted.
Regular index entries are (like @cindex) are 
formatted using the following function reference:
$command, $index_name, $entry_texi and $entry_formatted are the same as above, and $label is what could be used as a label, formatted using the function above.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
There is an elaborate default index formatting in texi2html, with
index summary by letter linking to index entries grouped by letters too,
with the possibility of index pages split accross files. This system may be 
completly bypassed by redefining the function reference that is called when
@printindex is encountered:
$index_name is the index name appearing on the 
@printindex line. The index formatted should be returned
by this function reference.
If the default index formatting is used, there are still possibilities to customize part of the formatting. The index entries are sorted alphabetically. A whole index list is considered to be composed of letter entries. A letter entry is composed by all the index entries beginning with that letter. A letter may be a non alphabetical character, but we call it letter here.
An index summary appears at the beginning and at the end of an index list,
and should be used to jump directly to a letter entry. Indices lists
may be split across pages, thus the different letters may appear on different
files. The number of index entries appearing on each page is determined
by a variable $SPLIT_INDEX
 if set. The default is to split
indices after 100 entries.
The formatting of all these elements is controlled by the following function references:
This function is used to format a letter appearing in a summary, refering to a letter entry in the index list. $letter is the letter. $file is the file name where the letter entry appears. More precisely, it is empty when the letter entry is on the same page than the summary, it contains the file name when the index page is split accross page. $identifier is an identifier for the target letter entry.
\@alphabetical_letters and \@nonalphabetical_letters contain the formatted summary letters, formatted with the above function.
$entry_href is a reference to the place where the index entry appeared, $entry_text is the corresponding text. $section_href is a reference to the beginning of the sectioning element containing the index entry, $section_heading is the heading of the element.
This function formats a letter entry, consisting in all the index entries beginning with this letter. $letter is the letter, $identifier should be used to create a target for links (typically links from summaries), and $index_entries_text is the text of the index entries formatted as described above.
$index_text is the text of all the index entries grouped by letter
appearing in that page formatted as above. It is undef if there are
no entries or theindex name isn’t known. index_name is the name of
the index, the argument of @printindex.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
Floats appear in the @float environment, optionaly with a style
and a label, and with optionnal @caption and @shortcaption. 
Their list appear after a @listoffloats. 
A hash reference is associated with each float, it is available in some formatting functions. The keys are:
caption_texishortcaption_texiA reference on an array containing the caption or shortcaption lines, with texi @-commands.
style_texiThe style with texi @-commands.
style_idThe unique identifier associated with the style.
styleThe style formatted.
nrThe number with the same conventions than makeinfo (use the chapter number a dot and then the number of the float of that style in the chapter, or an absolute number if in unnumbered).
chapter_nrThe number of the chapter containing the float.
nr_in_chapterThe number of the float in the chapter.
absolut_nrThe number of the float in the document.
texiThe label with @-commands.
nameThe label formatted.
idThe unique identifier associated with the label. Usefull to make an anchor or a reference.
targetThe target that can be used to refer to that float.
elementA reference on a structure representing the element the float appear in.
| 7.20.1 Formatting a float | Formatting of floats | |
| 7.20.2 Formatting lists of floats | Formatting the lists of floats | 
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
First there is an occasion to construct a texinfo text for the caption, using the caption texinfo lines and the informations in the float structure. The returned lines will be formatted in the main program. A function reference is used here:
\%float is the structure defined above. \@caption_lines and \@shortcaption_lines are references on arrays containing the texinfo lines for caption and short caption. \@caption_lines_returned and \@shortcaption_lines_returned are references on an array containing the texinfo lines for the caption and shortcaption.
Then the float is formatted with the following function reference:
$float_text is the text appearing within the @float, formatted.
\%float is still the structure defined above. $caption_text and
$shortcaption_text are the caption and short caption build with the
above function and formatted.
It is also possible to do something when a caption or a shortcaption appear with t hefollowing function reference:
$command is the @-command, ‘caption’ or ‘shortcaption’. $formatted_caption is the caption text, formatted, while \@texi_lines is a reference on an array containing the caption lines, this time without any formatting. \%float is still the structure defined above.
In the default case this function reference returns an empty string.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
A list of floats is introduced by @listoffloats. The argument of
@listoffloats is the style. First the style texinfo can be 
modified with the following function reference:
$style_texi is the @listoffloats argument with texinfo 
@-commands kept. It is possible to make changes to the $style_texi and
return a modified string, still with @-commands. The modified string
is formatted in the main program.
After that, for each of the floats with that style, first there is a possibility to modify the float style and the float caption before they are formatted in the main program, with the following function references:
$style_texi is the style, and \%float is the structure described above. This function reference returns a style to be formatted in the main program.
\%float is the structure described above. This function reference returns a caption to be formatted in the main program, \@caption_texi_returned, and a string, $caption_or_shortcaption that is either ‘caption’ or ‘shortcaption’ that can be used by the main program if this information is needed.
Each entry is formatted by:
$style_texi is the style with @-commands, $float_style is the style returned by the above function and formatted. $caption is the caption returned by the above function formatted. \%float is the structure corresponding with the float, and $href is an href pointing to the float location.
Lastly, the whole @listoffloats is formatted by:
$style_texi is the style with @-commands, $style is the style returned by the above function and formatted. The array reference \@listoffloats_entries holds the entries formatted by the above function.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
Each footnote is associated with a footnote entry. Several footnote entries are grouped in a footnote section. When a footnote appears, two things must be formatted: in the main text the place where the footnote appear and the footnote text.
Two functions, with corresponding function references control the formatting of the footnotes:
$number_in_doc is the footnote number in the whole document, $number_in_page is the footnote number in the current page. $footnote_id is an identifier for the footnote in the footnote text which should be used to make target for references to that footnote, while $place_id is an identifier for the location of the footnote in the main document. Similarly, $document_file is the file name of the file containing the text where the footnote appears in the main document, while $footnote_file is the file name of the file where the footnote text appears.
\@lines is a reference on an array containing the footnote text
lines, allready formatted.
And \%state holds informations about the context at the footnote
place in the main document. As usual the most usefull entry is 
preformatted which is true if the footnote appears in a preformatted 
context. 
This function returns a reference on an array, \@lines containing the updated footnote text for the footnote entry, and $text_for_document, the text appearing at the footnote place in the main document, linking to the footnote entry.
The following function is only used when footnotes are at the bottom of a page and the document is split. For customization of the footnotes page in case they are on a separated page or section, Customizing the layout of the special pages. For the determination of the footnote locations, Page layout related command line options.
This function formats a group of footnotes. \@footnotes_lines is a reference on an array holding the lines of all the footnote entries formatted as explained above. This function modifies the reference.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
The following function reference is called when a format is opened.
A format is any @-command that ends with a @end except 
@-commands that only select if the input is processed (like 
@ignore or @ifhtml) or raw @-commands (like @verbatim
and @html).
The $command is the format command, the $line is the line following the @-command, \%state is a reference on a hash containing many formatting information. It can modify the line and return something else.
In the default case, it is used to keep track of the multitable nesting. As a consequence, it is linked with the multitable formating. See Multitable formatting.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
It is possible to bypass completely the normal formatting of @-commands 
with braces and raw regions 
(@html, @tex, @xml… regions). 
In that case the @-commands and the text within 
are passed to a user defined function early, in a pass when no expansion
of output takes place, called the collecting pass. Another user defined 
function is called during the output expansion phase.
Moreover, arbitrary user defined functions may be called between the 
different texinfo parsing and outputting passes. This could be used, for
example to initialize some things before collecting the @-commands and their
text, expanding them between the collecting and expansion phase and doing
some cleaning after the expansion pass. These possibilities are used for
the interface to LaTeX2HTML 
(see section Expanding @tex and @math regions using LaTeX2HTML), and the examples are taken from that use.  
The @-commands that are keys of the %command_handler
 hash 
are collected in the collecting pass and expanded in the expansion
pass using user defined functions. The associated value is a reference on
a hash used to specify the user defined function references. 
The key of the hash reference are 'init' for the function
reference called during the collecting pass, and 'expand'
during the expansion pass. Here is an example for an @-command with
braces:
$command_handler{'math'} =
     { 'init' => \&Texi2HTML::LaTeX2HTML::to_latex,
       'expand' => \&Texi2HTML::LaTeX2HTML::do_tex
     };
And an example for a raw region @-command:
$command_handler{'tex'} =
     { 'init' => \&Texi2HTML::LaTeX2HTML::to_latex,
       'expand' => \&Texi2HTML::LaTeX2HTML::do_tex
     };
The function references are called like:
$command is the @-command name, $text is the text appearing within the @-command. $count is a counter counting how many times this @-command appeared. $status is a boolean which should be true if the collecting was succesfull. If false the @-command and the text is discarded.
$command is the @-command name, $count is a counter counting how many times this @-command appeared. $state is a reference on a hash containing many informations about the context. $text should be empty. $result is the expanded resulting text.
There are five places for user defined functions, associated with arrays:
@command_handler_setup
The function references in that array are called before anything is done, including collecting the output file names. The input file names directory are available.
@command_handler_init
The function references in that array are as soon as the file names are known. It may be at different moments, before processing anything, right after @sefilename, or at the end of the first pass (after @macro and @include expansions). At that time the information available is essentially the file names.
@command_handler_names
The function references in that array are called right after the collecting pass. At that time all the special @-commands have been collected as explained above but no output has been produced, the element (node and section) names hasn’t been processed and expanded.
@command_handler_process
The function references in that array are called after the element names have been processed, but before the main output initialization.
@command_handler_output
The function references in that array are called rigth before the main output processing, so that more informations are available, like the title.
@command_handler_finish
he function references in that array are called after the end of the output generation.
Here is an example of these arrays use:
push @command_handler_init, \&Texi2HTML::LaTeX2HTML::init; push @command_handler_process, \&Texi2HTML::LaTeX2HTML::latex2html; push @command_handler_finish, \&Texi2HTML::LaTeX2HTML::finish;
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
Special regions @titlepage, @documentdescription and
 @copying are removed from the document before the last pass in the
default case. They can be kept if the value associated with the @-command
in the %region_formats_kept
 hash is true.
The @insertcopying @-command is formatted by 
$text is the text appearing in @copying, formatted.
$comment is the text with texi removed, should be very simple
text. $simple_text is the text formatted in string context.
The title page handling is described in Formatting of title page.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
Many commands without braces are available in texinfo, sometimes with
a specific syntax. For example we have @sp, @noindent,
@documentlanguage, @oddheading, @headings,
@shortcontents, @shorttitlepage or @comment. 
texi2html interprets
some of these commands and some functions or variables are used for
their formatting or to access their information.
In the default case, however, most of these constructs are ignored.
It is possible to change how the things following these commands on the line are handled, what is considered to be an arg for those commands and it is also possible to keep them instead of discarding them such that it is possible to handle them specially, with the same function than the one used for unknown commands.
Those special commands without braces are the key of a hash:
%misc_command
. The associated value is a reference on a
hash enabling to set the properties of these commands. The
keys of this hash reference is the name of a property, the value
is the value of the property. For example here we have line
for the arg property for the command @-command.
$misc_command{'command'} = {'arg' => 'line', 'skip' => 'space'};
The properties and possible values are:
skipThis property enables to set what is skipped after the command arguments. Here are the possible values:
lineThe remaining of the line is skipped.
spaceSpaces are skipped but not newline.
whitespaceSpaces are skipped
linewhitespaceSpaces are skipped if there are only spaces remaining on the line.
linespaceSpaces are skipped, but not newline if there are only spaces remaining on the line
argIf the associated value is line the line is considered to be the
argument. If it is a number it is the number of args (separated by spaces).
keepIf true the args and the macro are kept, otherwise they are discarded.
The defaut is to have keep undef for all the commands.
If keep is true for @verbatiminclude the default
action for this macro isn’t done.
Commands which don’t appear in the hashes 
%simple_map
, %simple_map_pre
,
%simple_map_texi
 and %misc_command, or that appear in
%misc_command but with keep true are processed by the 
following function reference:
$command is the @-command, $line is the line following the 
$command. $pass is the pass of texi2html (see section Three passes: macro expansion, document structure and output). 
$result is a boolean. If it is true then the other return
values are taken into account otherwise the default actions are
used. In case $result is true, $result_line is the new line 
to be processed further, $result_text is the resulting formatted text 
and $message, if defined is a message outputted to the output
with line number added by texi2html.
Commands with braces not specified above 
nor in %style_map
, %style_map_pre
 and
%style_map_texi
 are processed 
by the following function reference
$command is the @-command, $text is the text appearing within 
the braces (allready formatted). $result is a boolean. If it is true then
the other return
values are taken into account otherwise the default actions are
used. In case $result is true, $result_text is the resulting
formatted text
and $message, if defined is a message outputted to the output
with line number added by texi2html.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
The strings written in the document are selected based on the
document language. This can be used to customize the strings, 
as described in Customizing strings written by texi2html. This also enables translation of the
strings. 
The gdt subroutine is used for translated strings:
with $string the string to be translated, \%variables_hash a reference on a hash holding the variable parts of the translated string, and \%state a hash reference determining the context of expansion (use the document state, expansion in string, no expansion...).
Translated strings are texinfo strings, which may have @-commands. In translated strings, the variables parts of the string are not denoted by %s and the like, but by ‘{arg_name}’ (which is common for perl gettext). For example, in the following, ‘{section}’ will be replaced by the section name:
see {section}
This is for 2 reasons, first changing the order of printf arguments is only available since perl 5.8.0, second the order of the argument may not be predictable when commands expansion may lead to different orders depending on the output format.
The expansion of those strings happens that way:
If the @documentlanguage is like ll_CC, ll_CC is tried first, and then ll. If the encoding is not us-ascii, us-ascii is also tried. The idea is that if there is a us-ascii encoding, it means that all the characters in the charset may be expressed as @-commands. For example there is a fr.us-ascii locale that can accomodate any encoding, since all the latin1 characters have associated @-commands. For the ja translations, there is only ja.utf-8 since there are no @-commands for ja letters.
For example, in the following ‘{date}’, ‘{program_homepage}’ and ‘{program}’
are the argument of the string. Since they are used in @uref, their
order in not predictable. The ‘{'duplicate'=>1}’ 
means the the document state
should be used when expanding the string. ‘{date}’, ‘{program_homepage}’ and ‘{program}’
are substituted after the expansion, which means that they
should already be acceptable output:
gdt('This document was generated on @i{{date}} using @uref{{program_homepage}, @i{{program}}}.', {
           'date' => $date, 'program_homepage' => $Texi2HTML::THISDOC{'program_homepage'}, 'program' => $Texi2HTML::THISDOC{'program'} },{'duplicate'=>1});
This approach is a bit complicated, however what is interesting is that it allows to have translation available in different encodings for charset that are covered by @-commands, and also to specify how the formatting for some commands is done independently of the output format but still allow it to be language dependent. For example, the ‘@pxref’ string may be:
see {node_file_href} section `{section}\' in @cite{{book}}
which allows to specify a string independently of the output format but with a rich formatting that may be differently translated in other languages.
It is also possible to use more regular %s escapes, and also avoid any expansion (with ’keep_texi’ in the state).
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
texi2html has accumulated a lot of incompatibilities with previous
versions. They are documented in the ‘NEWS’ file, we discuss them
here nevertheless. Most of the incompatibilities were introduced in 
version 1.68. API changed also a lot between 1.78 and 1.80. Between 
1.82 and 5.0 API changed also quite a bit, and more importantly, the
whole internationalization handling was changed.
'', `` --- and -- are transformed
  into entities. t2h_default_set_iso_symbols sets or unsets USE_ISO,
  %things_map/%pre_map/%simple_format_simple_map_texi, 
  $OPEN_QUOTE_SYMBOL and $CLOSE_QUOTE_SYMBOL.
  %iso_symbols is unused now.
copying key of %Texi2HTML::THISDOC is now called
copying_comment.
&$menu_comment is removed, menu_comment is now handled
  like an @-command.
@detailmenu is now formatted more like @menu, and
the &$menu function reference is replaced by &$menu_command.
&$menu is kept for backward compatibility. If &$menu is defined, 
@detailmenu is ignored.
$COMPLETE_IMAGE_PATHS set to true.
For example, if $CSS_LINES is defined, the value is put in $Texi2HTML::THISDOC{’CSS_LINES’} which is used for formatting, and if $CSS_LINES is not defined, $Texi2HTML::THISDOC{’CSS_LINES’} is autodetected.
makeinfo and also because it fits better with the cross
manuals reference scheme.
makeinfo. It seems
that in 1.66 it was the same than ‘-out-file’. 
‘--output’ new meaning allows to replace ‘-out-file’ and 
‘-subdir’ with a unique option. 
More precisely ‘-out-file’ forces the output to be unsplit while ‘--output’ behaves differently when split (it specifies the directory where the manual files should be outputted) and unsplit (it specifies the output file). ‘-subdir’ is retained for backward compatibility.
If you want a backward compatibility you can use ‘-subdir’ for the output directory if the document is split, and ‘-out-file’ if the document isn’t split. This hasn’t been tested extensively though.
It should be possible to do something similar with macros. See for example ‘glossary.texi’ for glossary and ‘my-bib-macros.texi’ for bibliography in the directory ‘examples’. In the web2c package there is an example of use of BibTeX, see http://tug.org/texlive/devsrc/Build/source/TeX/texk/web2c/doc/ (the examples for bibliography are taken from the texinfo home page http://www.gnu.org/software/texinfo/texinfo.html).
T2H_CENTER_IMAGE. @center should be used
insead, it will give the right output for all the formats.
Texi2HTML::Config names space instead of
variables prefixed with ‘T2H_’ or  ‘t2h_’. To cope with
the change the prefix should be removed from variables in init files.
Some variables are now in %Texi2HTML::THISDOC.
@ifinfo regions are not expanded by default. This may lead
to warnings or errors especially if the Top node is enclosed in 
@ifinfo, as some node won’t appear in menus. The quick fix
is to call texi2html with the option ‘--ifinfo’ and
the right way should be to make more use of @ifnottex.
@ifnothtml would be much cleaner.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
For features documented in the texinfo manual, the texinfo interpretation
by texi2html shouldn’t differ from the interpretation of
makeinfo or texi2dvi. However for constructs with 
unspecified behaviour texi2html often doesn’t lead to the 
same result than makeinfo or texi2dvi. makeinfo
and texi2dvi are also inconsistent in most of these cases (or
broken). You are urged not to use these features unless absolutely necessary.
This information is only here to help understand why texi2html
differ from other texinfo interpreters, it may be inacurate and the 
texi2html behaviour may change in the future and was different
in the past.
In the texinfo manual it is specified that block @-commands should appear
on a line without text and the closing @end should also be on a 
line by himself. With texi2html it is possible to add
text before and after the command, so the following is right:
something @example the example @end example after the example
makeinfo and texi2dvi may also accept text before
the command and text after the @end command, sometimes ignoring 
it after the @end.
This is a feature you should especially not rely on.
The special @-commands are commands like @pagesizes, @sp,
@evenheading, @raisesections, @defindex and a lot
more. In many cases makeinfo and texi2dvi 
don’t parse those commands the same way too. texi2html may also
show some differences in parsing of the arguments of these commands, 
in case there are wrong arguments, and also ignore differently things
following those commands. How user defined macros, set and values
are expanded in those commands may also be different.
Part of the specification of how these commands are handled is 
configureable (see section Customizing other commands, and unknown commands), but not what 
happens during the beginning of the parsing for some of those commands. 
makeinfo and texi2dviWhen makeinfo or texi2dvi use a feature which
is reserved for one or the other translator, texi2html uses that
feature. So for example @definfoenclose which is ignored by 
texi2dvi is taken into account and @kbdinputstyle which
is ignored by makeinfo is taken into account. 
In this area makeinfo and texi2dvi also differ a lot.
The reference implementation is the makeinfo implementation as
texi2dvi is easily broken when macros are not used simply.
@rmacro and @macro behave exactly the same. In fact
this goes against a documented behaviour, however if a user don’t
want a recursive macro he can simply avoid reusing the macro in the 
definition. If somebody report that the feature is usefull we could try
to implement it.
\@end macro
with the ‘\’ being removed after the first expansion. Otherwise
it is not possible to produce a \@end macro in a macro.
@unmacro is interpreted during the macro argument expansion.
Don’t know what makeinfo exactly do.
@value may be expanded later than the others, those
that are in special commands, like @node.
@, in @nodeLike texi2dvi but unlike makeinfo @, don’t 
break @node arguments like a regular ‘,’.
Things before the first node or before the preamble may not be exactly 
interpreted or discarded as makeinfo or texi2dvi do.
texi2html knows more encodings, in fact all encodings perl
knows about.
@ifset and @ifcleartexi2html doesn’t need a proper nesting of internal @ifset
or @ifclear if they are in ignored or raw regions (like @html
or @verbatim). For example the following is accepted by 
texi2html and not by makeinfo:
@ifset notset @ignore @ifset @end ignore @end ifset
In @ifset and @ifclear texi2html also accepts
a lot more of invalid constructs. For example the following is accepted
by texi2html but not by makeinfo:
@set flag @ifset flag @itemize @item my item @end ifset text @ifset flag @end itemize @end ifset
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
| Jump to: | C D E F H I L M N O P S T U V W | 
|---|
| Jump to: | C D E F H I L M N O P S T U V W | 
|---|
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
| Jump to: | $ % @ | 
|---|
| Jump to: | $ % @ | 
|---|
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
| Jump to: | A B C D E F I M P R S T U | 
|---|
| Jump to: | A B C D E F I M P R S T U | 
|---|
| [Top] | [Contents] | [Index] | [ ? ] | 
This behaviour is triggered only by a 
variable set in an init file,  $USE_SETFILENAME
(see section Use initialization files for fine tuning).
| [Top] | [Contents] | [Index] | [ ? ] | 
texi2htmltexi2html
  texi2html
  @tex and @math regions using LaTeX2HTMLtexi2html css linestexi2html
    @example, @display…)@verbatim, @cartouche, @quotation)| [Top] | [Contents] | [Index] | [ ? ] | 
texi2htmltexi2htmltexi2html| [Top] | [Contents] | [Index] | [ ? ] | 
This document was generated on July 26, 2016 using texi2html @PACKAGE_VERSION@.
The buttons in the navigation panels have the following meaning:
| Button | Name | Go to | From 1.2.3 go to | 
|---|---|---|---|
| [ << ] | FastBack | Beginning of this chapter or previous chapter | 1 | 
| [ < ] | Back | Previous section in reading order | 1.2.2 | 
| [ Up ] | Up | Up section | 1.2 | 
| [ > ] | Forward | Next section in reading order | 1.2.4 | 
| [ >> ] | FastForward | Next chapter | 2 | 
| [Top] | Top | Cover (top) of document | |
| [Contents] | Contents | Table of contents | |
| [Index] | Index | Index | |
| [ ? ] | About | About (help) | 
where the Example assumes that the current position is at Subsubsection One-Two-Three of a document of the following structure:
 
  This document was generated on July 26, 2016 using texi2html @PACKAGE_VERSION@.