Font::TTF::Post
Section: User Contributed Perl Documentation (3)
Updated: 2021-01-27
Page Index
NAME
Font::TTF::Post - Holds the Postscript names for each glyph
DESCRIPTION
Holds the postscript names for glyphs. Note that they are not held as an
array, but as indexes into two lists. The first list is the standard Postscript
name list defined by the TrueType standard. The second comes from the font
directly.
Looking up a glyph from a Postscript name or a name from a glyph number is
achieved through methods rather than variable lookup.
This class handles PostScript table types of 1, 2, 2.5 & 3, but not version 4.
Support for version 2.5 is as per Apple spec rather than MS.
The way to look up Postscript names or glyphs is:
$pname = $f->{'post'}{'VAL'}[$gnum];
$gnum = $f->{'post'}{'STRINGS'}{$pname};
INSTANCE VARIABLES
Due to different systems having different limitations, there are various class
variables available to control what post table types can be written.
- $Font::TTF::Post::no25
-
If set tells Font::TTF::Post::out to use table type 2 instead of 2.5 in case apps
cannot handle version 2.5.
- VAL
-
Contains an array indexed by glyph number of Postscript names. This is used when
writing out a font.
- STRINGS
-
An associative array of Postscript names mapping to the highest glyph with that
name. These may not be in sync with VAL.
In addition there are the standard introductory variables defined in the
standard:
FormatType
italicAngle
underlinePosition
underlineThickness
isFixedPitch
minMemType42
maxMemType42
minMemType1
maxMemType1
METHODS
$t->read
Reads the Postscript table into memory from disk
$t->out($fh)
Writes out a new Postscript name table from memory or copies from disk
$t->XML_element($context, $depth, $key, $val)
Outputs the names as one block of
XML
$t->minsize()
Returns the minimum size this table can be. If it is smaller than this, then the table
must be bad and should be deleted or whatever.
BUGS
- •
-
No support for type 4 tables
AUTHOR
Martin Hosken <
http://scripts.sil.org/FontUtils>.
LICENSING
Copyright (c) 1998-2016,
SIL International (
http://www.sil.org)
This module is released under the terms of the Artistic License 2.0.
For details, see the full text of the license in the file LICENSE.