7 .TH GROFF_FONT @MAN5EXT@ "18 April 1990" "Groff Version @VERSION@"
9 groff_font \- format of groff device and font description files
11 The groff font format is roughly a superset of the ditroff
13 Unlike the ditroff font format, there is no associated binary
15 The font files for device
17 are stored in a directory
19 There are two types of file: a
20 device description file called
27 there is no associated binary format.
29 The DESC file can contain the following types of line:
34 machine units per inch.
37 The horizontal resolution is
42 The vertical resolution is
47 The scale factor for pointsizes.
48 By default this has a value of 1.
59 commands are given in scaled points.
62 Quantities in the font files are given in machine units
63 for fonts whose point size is
68 This means that the postprocessor can handle the
74 .BI sizes\ s1\ s2\|.\|.\|.\|sn\ 0
75 This means that the device has fonts at
77 .IR s2 ,\|.\|.\|.\| sn
79 The list of sizes must be terminated by a
83 can also be a range of sizes
85 The list can extend over more than one line.
87 .BI styles\ S1\ S2\|.\|.\|.\|Sm
90 font positions will be associated with styles
93 .BI fonts\ n\ F1\ F2\ F3\|.\|.\|.\|Fn
96 will be mounted in the font positions
97 .IR m +1,\|.\|.\|., m + n
100 is the number of styles.
101 This command may extend over more than one line.
104 The default font family is
108 This line and everything following in the file are ignored.
109 It is allowed for the sake of backwards compatibility.
111 The res, unitwidth, fonts and sizes lines are compulsory.
112 Other commands are ignored by
114 but may be used by postprocessors to store arbitrary information
115 about the device in the DESC file.
117 A font file has two sections. The first section is a sequence
118 of lines each containing a sequence of blank delimited
119 words; the first word in the line is a key, and subsequent
120 words give a value for that key.
123 The name of the font is
127 The normal width of a space is
131 The characters of the font have a slant of
133 degrees. (Positive means forward.)
135 .BI ligatures\ lig1\ lig2\|.\|.\|.\|lign\ \fR[ 0 \fR]
138 .IR lig2 ,\|.\|.\|., lign
139 are ligatures; possible ligatures are
145 For backwards compatibiliy, the list of ligatures may be terminated
148 The list of ligatures may not extend over more than one line.
153 this means that when a character is requested that is not present in
154 the current font, it will be searched for in any special fonts that
157 Other commands are ignored by
159 but may be used by postprocessors to store arbitrary information
160 about the font in the font file.
162 The first section can contain comments which start with the
164 character and extend to the end of a line.
166 The second section contains one or two subsections.
170 and it may also contain a
173 These subsections can appear in any order.
174 Each subsection starts with a word on a line by itself.
178 starts the charset subsection.
181 line is followed by a sequence of lines.
182 Each line gives information for one character.
183 A line comprises a number of fields separated
184 by blanks or tabs. The format is
187 name metrics type code comment
190 identifies the character:
193 is a single character
195 then it corresponds to the groff input character
199 where c is a single character, then it
200 corresponds to the groff input character
202 otherwise it corresponds to the groff input character
204 (if it is exactly two characters
208 Groff supports eight bit characters; however some utilities
209 has difficulties with eight bit characters.
210 For this reason, there is a convention that the name
212 is equivalent to the single character whose code is
216 would be equivalent to the character with code 163
217 which is the pounds sterling sign in ISO Latin-1.
220 is special and indicates that the character is unnamed;
221 such characters can only be used by means of the
228 field gives the character type:
231 means the character has an descender, for example, p;
234 means the character has an ascender, for example, b;
237 means the character has both an ascender and a descender, for example,
242 field gives the code which the postprocessor uses to print the character.
243 The character can also be input to groff using this code by means of the
245 escape sequence (this feature is deprecated).
246 The code must be a number between 0 and 255.
249 it is assumed to be in octal.
251 Anything on the line after the code field will be ignored.
257 .IR width [\fB, height [\fB, depth [\fB, italic_correction [\fB, \
258 left_italic_correction [\fB, subscript_correction ]]]]]
260 There must not be any spaces between these subfields.
261 Missing subfields are assumed to be 0.
262 The subfields are all decimal integers.
263 Since there is no associated binary format, these
264 values are not required to fit into a variable of type
266 as they are in ditroff.
269 subfields gives the width of the character.
272 subfield gives the height of the character (upwards is positive);
273 if a character does not extend above the baseline, it should be
274 given a zero height, rather than a negative height.
277 subfield gives the depth of the character, that is, the distance
278 below the lowest point below the baseline to which the
279 character extends (downwards is positive);
280 if a character does not extend below above the baseline, it should be
281 given a zero depth, rather than a negative depth.
284 subfield gives the amount of space that should be added after the
285 character when it is immediately to be followed by a character
288 .I left_italic_correction
289 subfield gives the amount of space that should be added before the
290 character when it is immediately to be preceded by a character
293 .I subscript_correction
294 gives the amount of space that should be added after a character
295 before adding a subscript.
296 This should be less than the italic correction.
298 A line in the charset section can also have the format
305 is just another name for the character mentioned in the
310 starts the kernpairs section.
311 This contains a sequence of lines of the form:
316 This means that when character
318 appears next to character
320 the space between them should be increased by
322 Most entries in kernpairs section will have a negative value for
325 .TP \w'@FONTDIR@/devname/DESC'u+3n
326 .BI @FONTDIR@/dev name /DESC
327 Device description file for device
330 .BI @FONTDIR@/dev name / F
336 .BR groff_out (@MAN5EXT@),
337 .BR gtroff (@MAN1EXT@).