afm2pl converts an afm (Adobe Font Metric) file into a pl (Property List) file, which in its turn can be converted to a tfm (TeX Font Metric) file. It preserves kerns and ligatures.
afm2pl is meant to be a replacement for afm2tfm, on which it is based. With afm2tfm, preserving kerns and ligatures is possible only in a roundabout way.
For text fonts, Y&Y’s texnansi is the recommended encoding to be used with afm2pl. This gives you a good character set with all the more important accented characters and many typographic symbols available as single characters, without a need for either virtual fonts or a separate text companion font.
Full LaTeX support for this encoding is available in the form of the texnansi package, which is already part of TeX Live and teTeX. These distributions also contain the encoding file texnansi.enc.
The distribution contains uppercased and lowercased versions of texnansi, viz. texnanuc.enc and texnanlc.enc, to allow font-based rather than macro-based uppercasing and lowercasing, and the familiar old ot1 encoding plus some variations in PostScript .enc format (I included these because they seem to be absent from teTeX/TeX Live).
Return value: 0 if no error; a negative number indicating the number of missing glyphs if conversion was successfull but glyphs are missing, and 1 in case of error.
Font dimension | Default value | Afm2tfm value |
stretch | ||
shrink | space div 3 | 100 x extend_factor |
extra space | space div 3 | missing |
quad | 2 x width of ’0’ | 1000 x extend_factor |
space | (space source font) x extend_factor | (space source font) x extend_factor |
Font dimension | Default value | Afm2tfm value |
stretch | ||
shrink | 0 | 0 |
extra space | space | missing |
quad | 2 x character width | 1000 x extend_factor |
space | character width | character width |
afm2pl writes a mapfile entry to a file with the same basename as the pl output file, but with extension .map. It can be used for the dvips mapfile and for the pdftex mapfile, although, in case of a geometrically transformed font, it may be better to remove the PostScript name for a pdftex mapfile entry. It is assumed that the pfb file has the same basename as the afm file and must be downloaded. You may have to hand-edit this entry.
You can configure dvips and pdftex to read this additional mapfile or otherwise add the entry to an existing mapfile. It appears that pdftex automatically will consult a mapfile xxx.map for a font xxx.
Most users are well-advised to leave this mess alone and to accept the default behavior.
The ligatures and kerns present in the afm file can be modified in various ways. Default, the encoding file is scanned for extra ligkern specifications, whose format will be described below. If there are no ligkern specifications in the encoding file, then extra ligkern specifications will be read from a file default.lig. A value of 0 for ligkern_spec means that the ligatures and kerns from the afm file won’t be tampered with and a value of 1 specifies default behavior. One can also specify a comma-separated list of files with extra ligkerns specs.
If afm2pl is compiled with the kpathsea library, then these files will be searched for under $TEXMF/fonts/lig.
Note that ligatures and kerns are hints for the typesetting application; there is no need to download this information to the printer or to make it available to a dvi driver.
The parser for ligkern info has been inherited from afm2tfm virtually without change. A ligkern specification can have one of the following forms:
This specifies a ligature. Possible values for lig_op are =:, |=:, |=:>, =:|, =:|>, |=:|, |=:|> and |=:|>>. These correspond to LIG, /LIG, /LIG>, LIG/, LIG/>, /LIG/, /LIG/>, /LIG/>> in .pl syntax; see the pltotf documentation and the .lig files in the distribution.
Kern glyph_name1 as glyph_name2.
Remove the kern between glyph_name1 and glyph_name2. A value of * for either glyph name is interpreted as a wildcard.
Set the (right) boundary character to glyph. glyph may be either a glyphname or a slot in the encoding vector. Choosing a glyph which doesn’t occur in the output encoding is equivalent to not specifying a boundarychar at all. It is ok to pick an encoded glyphname which does not occur in the afm. In fact, this is what default.lig does: || = cwm ;.
You can copy the kerns of an unencoded character to the boundarychar:
This ligkern specification should occur before the one that deletes space kerns.
A ligkern specification should be contained within one line. One line may contain several ligkern specifications, separated by spaces. Note that ; (space followed by semicolon) is considered part of the ligkern specification. See the lig files included in this distribution. Example:
Lines with ligkern specifications inside an encoding file should start with % LIGKERN. Ligkern specifications in a lig file may optionally start this way.
Letterspacing has various side-effects for ligkern info. Instead of simply applying the extra ligkern info (see previous section), the following is done:
The distribution includes encoding vectors texnanuc.enc and texnanlc.enc which produce all-uppercase and all-lowercase fonts. The distribution contains an example ucshape.tex on how to use such fonts with LaTeX font selection.
The principal uses for an all-uppercase font are page headers and section heads. If these contain math, then macro-based uppercasing would create unpleasant complications.
Note that the texnanuc encoding provides no glyph for the sz ligature; you’ll either have to substitute ss or provide a macro-based solution. The following code uses either the usual glyph or substitutes the letters ss, depending on whether the glyph exists in the current font:
\def\ss{% \setbox0\hbox{\char25}% \ifnum\wd0=0 ss\else\box0\fi }
In LaTeX, this code appears to work well enough, although on occasion you may need to insert \protect. A better solution might involve the sixth parameter of the \DeclareFontShape macro, but I failed to get that to work.
Afm2pl currently doesn’t do virtual fonts. That means that for things such as artificial smallcaps you have to turn elsewhere, e.g. to the fontinst package, which is part of any mainstream TeX distribution.
Look under texmf/tex/fontinst for fontinst support files, which allow you to generate a smallcaps font (tfm and vf files) from an afm2pl-generated tfm file. This package only supports texnansi encoding.
There should be no real problem in doing the same for OT1 encoding. However, there are several variations of the OT1 encoding to take care of. Also, there are as far as I know no officially sanctioned PostScript names for all the variations of the OT1 encoding; the fontinst names contain spaces and are therefore not useable as PostScript names.
I am considering a revision which makes afm2pl a more complete replacement for afm2tfm. In that version, afm2pl can optionally create a second, virtual font, possibly with a different encoding and possibly letterspaced. The current option of non-virtual letterspacing via kerns will be dropped. If the encodings differ then it is assumed that the virtual font is intended as a small-caps version of the main font, and a scaling parameter can be specified for non-matching glyphs.
The afm2pl distribution is subject to the GNU General Public Licence (GPL). Please refer to the file COPYING for details.
The afm2pl homepage is http://www.ntg.nl/afm2pl.html: http://www.ntg.nl/afm2pl.html.