| Current File : //usr/share/info/ogonkify.info |
This is ogonkify.info, produced by makeinfo version 3.12i from
ogonkify.texi.
INFO-DIR-SECTION Printing Tools
START-INFO-DIR-ENTRY
* ogonkify: (ogonkify). Ogonkify
END-INFO-DIR-ENTRY
This is the Ogonkify manual, Copyright (C) 1996-1999 by Juliusz
Chroboczek.
File: ogonkify.info, Node: Top, Next: License, Prev: (dir), Up: (dir)
The Ogonkify package
********************
The Ogonkify package contains two programs: a utility for adding
composite characters to fonts in a semi-automatic fashion, and a program
for converting PS output -- notably Netscape and Mosaic output -- to use
these fonts.
* Menu:
* License:: Your rights and my polite requests
* Using Ogonkify:: How to use Ogonkify
* Adding new characters:: How to add new characters to the fonts
* Reaching the author:: Addresses
File: ogonkify.info, Node: License, Next: Using Ogonkify, Prev: Top, Up: Top
The McKornik Jr. Public License
*******************************
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by the
Free Software Foundation; either version 3 of the License, or (at your
option) any later version.
In particular, this program is provided as is, without any warranty,
not even of any kind. It might (or might not) do what it is supposed
to do, it might (or might not) destroy your printer, and it might (or
might not) be useful to you. In any case, you are on your own.
This program is written in Perl. While stronger people find reading
Perl code character-building, it should not be shown to people in their
formative years. The author will not accept any responsibility for any
moral grief caused.
I would like to ask you _not_ to distribute the generated fonts
without including a pointer to the original AFMs and the rest of the
code. Furthermore, please notify me if you decide to include this code
in a larger piece of software.
If you find this software useful, local goodies, makowiec, beer from
Zywiec, postcards from exotic places and all sorts of things are
accepted.
File: ogonkify.info, Node: Using Ogonkify, Next: Adding new characters, Prev: License, Up: Top
Using Ogonkify
**************
This chapter describes the various uses of Ogonkify.
* Menu:
* Ghostscript:: Viewing with ghostscript
* Standard Applications:: Using the package with standard applications
* a2ps:: Printing with a2ps
* genscript:: Printing with genscript
File: ogonkify.info, Node: Ghostscript, Next: Standard Applications, Prev: Using Ogonkify, Up: Using Ogonkify
Viewing with Ghostscript
========================
Due to a bug in some versions of ghostscript, in order to view the
output of Ogonkify you may need to run ghostscript with the
`-dNOPLATFONTS' option, as in
gs -dNOPLATFONTS foo.ps
or in
ghostview -arguments -dNOPLATFONTS foo.ps
See the `gs(1)' and `ghostview(1)' manual pages for more details.
File: ogonkify.info, Node: Standard Applications, Next: a2ps, Prev: Ghostscript, Up: Using Ogonkify
Printing from Standard Applications
===================================
The main use of Ogonkify is to allow various standard applications to
print in various languages. As of this writing, the `ogonkify' script
knows how to handle Netscape, Mosaic, the mail printer MP, StarOffice,
and ApplixWare. Its usage is described in full detail in the
`ogonkify(1)' manual page.
File: ogonkify.info, Node: a2ps, Next: genscript, Prev: Standard Applications, Up: Using Ogonkify
Printing with a2ps
==================
`a2ps' is a PostScript formatter with pretty-printing capabilities.
Starting with version 4.7.21, it automatically uses Ogonkify, which is
distributed with it. *Note a2ps manual: (a2ps.info)top.
`a2ps' can be obtained from:
<URL:http://www-stud.enst.fr/~demaille/a2ps.html>
File: ogonkify.info, Node: genscript, Prev: a2ps, Up: Using Ogonkify
Printing with GNU Enscript
==========================
GNU Enscript is a program for printing text files on PostScript
printers written by Markku Rossi and distributed with other GNU
software. You will find it on any mirror carrying GNU software.
GNU Enscript is one of the few programs that allow the user to select
the encoding of the files he wants to print, and correctly reencoding
the fonts it uses . In order to obtain information about the characters
available in a font, it uses AFM files.
If you are only interested in printing in Courier, you might want to
simply use the IBM Courier fonts and the AFM files provided with them.
However, you may also want to use the output of Ogonkify; for printing
in Times and Helvetica, this is the only solution.
Here are installation procedures for using the fonts generated by the
`instogonki' script with `genscript'. They assume that `genscript' is
properly installed, and that you know which `genscript.cfg' file it
reads.
1. In the directory `$PFADIR', type
% mkafmmap *.afm
(the `mkafmmap' program is installed with GNU Enscript).
2. In the `genscript.cfg' file, add your `$PFADIR' directory to the
AFMPath.
You can now print with the composite characters. Example:
% genscript -X latin2 -f Times-Roman-Ogonki@12 \
-o wierszyk.ps wierszyk.txt
or
% genscript -X latin2 -f Helvetica-Ogonki@12 \
-o wierszyk.ps wierszyk.txt
File: ogonkify.info, Node: Adding new characters, Next: Reaching the author, Prev: Using Ogonkify, Up: Top
Adding new characters
*********************
This chapter attempts to explain how to extend Ogonkify to handle
supplementary characters.
* Menu:
* Composite background:: Background about composite characters
* AFM files:: Non-orthodox use of Adobe Font Metric files
* Generated fonts:: Fonts with composite characters
* Composite usage:: Usage of the script `composeglyphs'
* Composite example:: A step-by-step example
File: ogonkify.info, Node: Composite background, Next: AFM files, Prev: Adding new characters, Up: Adding new characters
Background
==========
A typical Type 1 font for the latin alphabet contains "pure"
characters, such a `A' or `acute', and composite characters, such as
`Aacute', which are composed of the `A' character, and the `acute'
character using the Type 1 `seac' operator.
Unfortunately, most fonts do not contain all the characters in the
ISO Latin-2 character set. In particular, most of the Polish characters
(with the exception of `oacute' and `Oacute') are usually missing (a
notable exception is IBM Courier -- not Adobe Courier -- which contains
many useful glyphs). However, the components of those glyphs are
present. It should not be difficult to add the characters we need if
the necessary tools were available... At least four methods could be
used:
i) Do not change the original font, but do overstriking for individual
characters (e.g. typeset an `a', then move backwards and typeset an
`ogonek' for `aogonek'). This method is widely used, for instance by
TeX.
ii) Parse the `PFA' or `PFB' file containing the font program for a
Type 1 font, and generate a new `PFA' containing the composite
characters. This should not be too difficult (`PFA' parsers are freely
available), but would require that users have the `PFA' files
corresponding to the fonts they use, which is often not the case.
Furthermore, I believe that it would violate the license of the fonts.
I am not quite sure what to make of the following:
Adobe Systems' Type 1 font programs are licensed for use on one or
more devices (depending on the terms of particular licenses).
These licenses would permit the use of a licensed program in a
system that translates a Type 1 font program to some other format
in the process of rendering, as long as a copy of the program
(even in translated form) is not produced.
`Adobe Type 1 Font Format', p. 7, Adobe Systems Inc.
iii) Download the original font, and add to its Charstrings dictionary
the supplementary characters using PostScript. This would not violate
the license agreement as the modified font would exist only in the
printer. However, many PostScript interpreters do not allow tampering
with Type 1 font dictionaries. Copy protection, as always, only bothers
honest users.
iv) Create a new Type 3 font dictionary which draws characters by using
the characters in the original font. This has the benefits of working
and being legal. I expected it to be quite inefficient, but found it
to be reasonably fast.
The `composite.ps' file contained in this distribution, and the
accompanying perl program `composeglyphs', follow scheme (iv). The
following sections describe them in more detail, including information
on extending the code to create other composite characters.
*Please note:* our usage of the word "composite" has noting to do
with Adobe's notion of "composite fonts". This is a bug.
*Please note:* a Polish typographer would be appalled to see that
we consider the "ogonek" as a diacritical mark, and thus harm the
integrity of the two letters that all Poles love. Indeed, in a
proper Polish font, the tail of `aogonek' would have a different
shape than that of `eogonek'. Considering however the poor
availability of fonts with the needed characters, we do not
currently have the luxury to whine about such esthetic problems.
File: ogonkify.info, Node: AFM files, Next: Generated fonts, Prev: Composite background, Up: Adding new characters
Non-orthodox uses of Adobe Font Metrics files
=============================================
Information about the fonts comes from "Adobe Font Metrics" (AFM)
files. Much more information is in AFMs then usually known; in
particular, the encoding vector can be derived from the AFM, and AFMs
contain the composite character information. Therefore, a program could
generate the needed font -- encoding vector and everything included --
from the AFMs.
In order to simplify the handling of AFM information, we use three
different AFMs on every run of the program: (i) an AFM with the encoding
vector to use, (ii) the AFM of the original font, and (iii) an AFM with
supplementary composite character information. The latter will usually
have to be supplied by the user. It is needed because AFMs provided
with Type 1 fonts usually only contain composite information about the
characters already in the font (in fact, the Adobe documentation does
not make it quite clear whether it is legal to insert composite
information about characters not already in the font into an AFM).
File: ogonkify.info, Node: Generated fonts, Next: Composite usage, Prev: AFM files, Up: Adding new characters
Fonts with composite characters
===============================
The generated font contains (i) the characters that were in the
original font, and (ii) the characters which were not in the original
font but for which composite information was provided. AFM files for
the generated fonts are generated too, which means that the fonts can be
used with most applications. Furthermore, they can be reencoded, just
like any well-behaved PostScript font.
In order to maintain compatibility with PostScript Level 1, every
composed font must be based on a base encoding vector, and characters
can only be composed from components in that vector. Thus, in order to
build `Nacute' from `N' and `acute', both `N' and `acute' must be in
the base vector.
However, as the base vector is only ever used internally, much
liberty can be taken when designing it. In particular, it doesn't need
to be compatible with any other vector, and there is no reason to avoid
the control character range. The base encoding vector that I use is
called `OgonkiEncoding'; it is based on Latin-2, but contains all the
characters of `StandardEncoding' (although in strange places).
There is a limitation on the composite information that can be used.
In particular, the only composite entries used are of the form:
CC ... 2 ; PCC x 0 0 ; PCC ' ... ; ...
In plain words, there must be exactly two characters to compose, the
first character must be set at the origin, and the width of the
composite character is taken to be that of the first character. This
limitation is easy to lift, and I will generalize the code if you send
me AFMs that do not obey this convention (I have never seen any, and,
indeed, this is the format required by the Type 1 `seac' operator).
AFMs that do not obey it are (hopefully) gracefully handled (you should
see warnings about `CC' entries being ignored).
File: ogonkify.info, Node: Composite usage, Next: Composite example, Prev: Generated fonts, Up: Adding new characters
Usage of the composite script
=============================
The `composeglyphs' script can be run to generate either an encoding
vector or a new font. It is a perl script, and only reformats the data;
the real magic is in the file `composite.ps'.
In order to generate an encoding vector from a suitable AFM,
`composeglyphs' is run as follows:
% composeglyphs -e latin2.afm -E latin2.enc
which will generate the file `latin2.enc' from the AFM file
`latin2.afm' (this is the default). Any AFM file is suitable as input,
but most AFMs do not contain all the possible characters of an encoding
vector (the missing ones will be replaced by `.notdef').
In order to generate a font program, more input must be provided:
% composeglyphs -i ptmr.afm -c ptmr-c.afm \
-o ptmr-o.ps -n Times-Roman-Ogonki \
-a ptmr-o.afm \
-e ogonki.afm -t adobe.afm
where `-i' specifies the AFM of the original font, `-c' supplementary
composite character information, `-o' the font program to generate,
`-n' the name of the new font, `-a' the name of the AFM file to
generate, `-e' the base encoding AFM to use, and `-t' the target
encoding.
The file `makecomp' contains a shell script (run by the installation
program) which generates fonts with composite characters for the Times,
Courier and Helvetica families from the supplementary AFMs `*-c.afm'.
File: ogonkify.info, Node: Composite example, Prev: Composite usage, Up: Adding new characters
A step-by-step example
======================
Assume that you want to add the `ccaron' and `Ccaron' characters to
the Times-Roman font. Start from similar characters already present in
the base Times-Roman font -- for example, `zcaron' and `Zcaron'. Take
the corresponding "composite character" (`CC') line from the `ptmr.afm'
file:
CC zcaron 2 ; PCC z 0 0 ; PCC caron 55 0 ;
and insert it into the `ptmr-c.afm' file, changing the names of the
characters thus:
CC ccaron 2 ; PCC c 0 0 ; PCC caron 55 0 ;
This line can be used as a starting point. Execute `./instogonki',
typeset some text with the new character, and fine-tune the last set of
coordinates (`55 0').
If you create new AFMs or modify the existing ones, please send me a
copy so that I can include them in the distribution.
File: ogonkify.info, Node: Reaching the author, Prev: Adding new characters, Up: Top
Reaching the author
*******************
This manual and most of the Ogonkify package were written by Juliusz
Chroboczek, <jec@dcs.ed.ac.uk>.
My current snail-mail address is:
Juliusz Chroboczek
Department of Computer Science
Mayfield Road
Edinburgh EH9 3JZ
Scotland, United Kingdom
tel. +44/131/650-5163
fax. +44/131/667-7209
Tag Table:
Node: Top276
Node: License866
Node: Using Ogonkify2161
Node: Ghostscript2602
Node: Standard Applications3086
Node: a2ps3571
Node: genscript4003
Node: Adding new characters5548
Node: Composite background6146
Node: AFM files9661
Node: Generated fonts10868
Node: Composite usage12867
Node: Composite example14413
Node: Reaching the author15327
End Tag Table