HEVEA can be controlled by writing LATEX code. In this section, we examine how users can change HEVEA default behaviour or add functionalities. In all this section we assume that a document doc.tex is processed, using a private command file macros.hva. That is, HEVEA is invoked as:
# hevea macros.hva doc.tex
The general idea is as follows: one redefines LATEX constructs in macros.hva, using internal commands. This requires a good working knowledge of both LATEX and html. Usually, one can avoid internal commands, but then, all command redefinitions interact, sometimes in very nasty ways.
Users can easily change the rendering of some constructs. For instance, assume that all quotations in a text should be emphasised. Then, it suffices to put the following re-declaration in macros.hva:
\renewenvironment{quote} {\@open{blockquote}{}\@style{em}} {\@close{blockquote}}
The same effect can be achieved without using any of the internal commands:
\let\oldquote\quote \let\oldendquote\endquote \renewenvironment{quote}{\oldquote\em}{\oldendquote}
In some sense, this second
solution is easier, when one already knows
how to customise LATEX. However, this is less safe, since the definition of
\em
can be changed elsewhere.
There is yet another solution that takes advantage of style sheets. One can also add this line to the macros.hva file:
\newstyle{.quote}{font-style:oblique;}
This works because the environment quote is styled through
style class quote (see Section 9.2).
Notice that this solution has very little to do with
“emphasising” in the proper sense, since here we
short-circuit the implicit path from \em
to oblique fonts.
HEVEA default rendering of type style changes is described in section B.15.1. For instance, the following example shows the default rendering for the font shapes:
\itshape italic shape \slshape slanted shape \scshape small caps shape \upshape upright shape
By default, \itshape
is italics, \slshape
is oblique
italics, \scshape
is small-caps (thanks to style sheets) and \upshape
is no style at all.
All shapes are mutually exclusive, this means that each shape
declaration cancels the effect of other active shape declarations.
For instance, in the example, small caps shapes is small caps (no italics here).
italic shape slanted shape small caps shape upright shape
If one wishes to change the rendering of some of the shapes (say slanted
caps), then one should redefine the old-style \sl
declaration.
For instance, to render slanted as Helvetica (why so?), one should
redefine \sl
by \renewcommand{\sl}{\@span{style="font-family:Helvetica"}}
in
macros.hva.
And now, the shape example above gets rendered as follows:
italic shape slanted shape small caps shape upright shape
Redefining the old-style \sl
is compatible with the cancellation
mechanism, redefining \slshape
is not.
Thus, redefining directly LATEX 2є \slshape
with
\renewcommand{\slshape}{}
would yield:
italic shape slanted shape small caps shape upright shape
Hence, redefining old-style declarations using internal commands should yield satisfactory output. However, since cancellation is done at the html level, a declaration belonging to one component may sometimes cancel the effect of another that belongs to another component. Anyway, you might have not noticed it if I had not told you.
Assume for instance that the base style of doc.tex is
jsc (the
Journal of Symbolic Computation style for articles).
For running HEVEA, the jsc style can be replaced by
article
style, but for a few commands whose calling interface is changed.
In particular, the \title
command
takes an extra optional argument (which HEVEA should ignore
anyway).
However, HEVEA can process the document as it stands.
One solution to insert the following lines into macros.hva:
\input{article.hva}% Force document class 'article' \let\oldtitle=\title \renewcommand{\title}[2][]{\oldtitle{#2}}
The effect is to replace \title
by a new command which
calls HEVEA \title
with the appropriate argument.
HEVEA fully implements LATEX 2є \newcommand
.
That is, users can define commands with an optional argument.
Such a feature permits to write a \epsfbox
command that
has the same interface as the LATEX command and
echoes itself as it is invoked to the image file.
To do this, the HEVEA \epsfbox
command has to check
whether it is invoked with an optional argument or not.
This can be achieved as follows:
\newcommand{\epsfbox}[2][!*!]{% \ifthenelse{\equal{#1}{!*!}} {\begin{toimage}\epsfbox{#2}\end{toimage}}%No optional argument {\begin{toimage}\epsfbox[#1]{#2}\end{toimage}}}%With optional argument \imageflush}
Semi-automatic generation of included images is described in
section 6.
Links to included images are generated by the \imageflush
command, which calls the \imgsrc
command:
\newcommand{\imageflush}[1][] {\@imageflush\stepcounter{image}\imgsrc[#1]{\hevaimagedir\jobname\theimage\heveaimageext}}
That is, you may supply a html-style attribute to the included image,
as an optional argument to the \imageflush
command.
By default, images are PNG images stored in .png files. HEVEA provides support for the alternative GIF image file format. It suffices to invoke hevea as:
Then imagen must be run with option -gif:
A convenient alternative is to invoke hevea as:
Then hevea will invoke imagen with the appropriate
option when it thinks images need to be rebuild.
An even more convenient alternative is to load gif.hva
from within document source, for instance with the \usepackage
command.
HEVEA also provides support for the alternative SVG image file format. As for GIF images, it is more convenient to use option -fix to combine hevea and imagen invocations:
Notice that imagen production chain of SVG images always call pdflatex, even when not given the -pdf command-line option. Hence the source code of images must be processable by pdflatex. This precludes using latex-only packages such as pstricks for instance.
As not all browsers display SVG images, hevea and
imagen are bit special:
imagen produces both PNG9 and SVG images; while hevea offers both image sources,
letting client browser select the most appropriate one by the means of
the srcset
attribute of the img
element.
By redefining the \heveaimagedir
command, users can specify a
directory for images.
More precisely, if the following redefinition occurs in the document
preamble.
\renewcommand{\heveaimagedir}{
dir}
Then, all links to images in the produced html file will be as “dir/…”. Then imagen must be invoked with option - todir:
As usual, hevea will invoke imagen with the appropriate option, provided it is passed the -fix option.
The internal command
\@addimagenopt{
option}
add
the text option to imagen command-line options, when
launched automatically by hevea (i.e. when
hevea is given the -fix command-line option).
For instance, to instruct hevea/imagen to reduce all images by a factor of √2, it suffices to state:
\@addimagenopt{-mag 707}
See section C.1.5 for the list of command-line options accepted by imagen.