]> git.wh0rd.org - fontconfig.git/blame - doc/fontconfig-devel.sgml
Change files from ISO-Latin-1 to UTF-8
[fontconfig.git] / doc / fontconfig-devel.sgml
CommitLineData
22671e25 1<!DOCTYPE article PUBLIC "-//OASIS//DTD DocBook V3.1//EN" [
39381776
KP
2<!ENTITY fcatomic SYSTEM "fcatomic.sgml">
3<!ENTITY fcblanks SYSTEM "fcblanks.sgml">
22671e25 4<!ENTITY fccharset SYSTEM "fccharset.sgml">
39381776
KP
5<!ENTITY fcconfig SYSTEM "fcconfig.sgml">
6<!ENTITY fcconstant SYSTEM "fcconstant.sgml">
7<!ENTITY fcfile SYSTEM "fcfile.sgml">
bfc2dc3a 8<!ENTITY fcfontset SYSTEM "fcfontset.sgml">
39381776
KP
9<!ENTITY fcfreetype SYSTEM "fcfreetype.sgml">
10<!ENTITY fcinit SYSTEM "fcinit.sgml">
11<!ENTITY fcmatrix SYSTEM "fcmatrix.sgml">
bfc2dc3a
KP
12<!ENTITY fcobjectset SYSTEM "fcobjectset.sgml">
13<!ENTITY fcobjecttype SYSTEM "fcobjecttype.sgml">
39381776
KP
14<!ENTITY fcpattern SYSTEM "fcpattern.sgml">
15<!ENTITY fcstring SYSTEM "fcstring.sgml">
16<!ENTITY fcstrset SYSTEM "fcstrset.sgml">
17<!ENTITY fcvalue SYSTEM "fcvalue.sgml">
fddb839b 18<!ENTITY version SYSTEM "version.sgml">
22671e25 19]>
584ac89a
KP
20<!--
21 $Id$
22
46b51147 23 Copyright © 2003 Keith Packard
584ac89a
KP
24
25 Permission to use, copy, modify, distribute, and sell this software and its
26 documentation for any purpose is hereby granted without fee, provided that
27 the above copyright notice appear in all copies and that both that
28 copyright notice and this permission notice appear in supporting
29 documentation, and that the name of Keith Packard not be used in
30 advertising or publicity pertaining to distribution of the software without
31 specific, written prior permission. Keith Packard makes no
32 representations about the suitability of this software for any purpose. It
33 is provided "as is" without express or implied warranty.
34
35 KEITH PACKARD DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
36 INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO
37 EVENT SHALL KEITH PACKARD BE LIABLE FOR ANY SPECIAL, INDIRECT OR
38 CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE,
39 DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
40 TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
41 PERFORMANCE OF THIS SOFTWARE.
42-->
43<article>
fddb839b 44 <title>Fontconfig Developers Reference, Version &version; </title>
22671e25
KP
45 <artheader>
46 <author>
47 <firstname>Keith</firstname>
48 <surname>Packard</surname>
49 <affiliation><orgname>
50 HP Cambridge Research Lab
51 </orgname></affiliation>
52 </author>
53 <authorinitials>KRP</authorinitials>
54 <productname>Fontconfig</productname>
fddb839b 55 <productnumber>&version;</productnumber>
22671e25
KP
56 <LegalNotice>
57 <simpara>
46b51147 58Copyright © 2002 Keith Packard
22671e25
KP
59 </simpara><simpara>
60Permission to use, copy, modify, distribute, and sell this software and its
61documentation for any purpose is hereby granted without fee, provided that
62the above copyright notice appear in all copies and that both that
63copyright notice and this permission notice appear in supporting
64documentation, and that the name of Keith Packard not be used in
65advertising or publicity pertaining to distribution of the software without
66specific, written prior permission. Keith Packard makes no
67representations about the suitability of this software for any purpose. It
68is provided "as is" without express or implied warranty.
69 </simpara><simpara>
70KEITH PACKARD DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
71INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO
72EVENT SHALL KEITH PACKARD BE LIABLE FOR ANY SPECIAL, INDIRECT OR
73CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE,
74DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
75TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
76PERFORMANCE OF THIS SOFTWARE.
77 </simpara>
78 </LegalNotice>
79 </artheader>
584ac89a
KP
80<sect1><title>DESCRIPTION</title>
81 <para>
82Fontconfig is a library designed to provide system-wide font configuration,
83customization and application access.
84 </para>
85</sect1>
86<sect1><title>FUNCTIONAL OVERVIEW</title>
87 <para>
88Fontconfig contains two essential modules, the configuration module which
89builds an internal configuration from XML files and the matching module
90which accepts font patterns and returns the nearest matching font.
91 </para>
92 <sect2><title>FONT CONFIGURATION</title>
93 <para>
94The configuration module consists of the FcConfig datatype, libexpat and
95FcConfigParse which walks over an XML tree and ammends a configuration with
96data found within. From an external perspective, configuration of the
97library consists of generating a valid XML tree and feeding that to
98FcConfigParse. The only other mechanism provided to applications for
99changing the running configuration is to add fonts and directories to the
100list of application-provided font files.
101 </para><para>
102The intent is to make font configurations relatively static, and shared by
103as many applications as possible. It is hoped that this will lead to more
104stable font selection when passing names from one application to another.
105XML was chosen as a configuration file format because it provides a format
106which is easy for external agents to edit while retaining the correct
107structure and syntax.
108 </para><para>
109Font configuration is separate from font matching; applications needing to
110do their own matching can access the available fonts from the library and
111perform private matching. The intent is to permit applications to pick and
112choose appropriate functionality from the library instead of forcing them to
113choose between this library and a private configuration mechanism. The hope
114is that this will ensure that configuration of fonts for all applications
115can be centralized in one place. Centralizing font configuration will
116simplify and regularize font installation and customization.
117 </para>
118 </sect2>
119 <sect2>
120 <title>FONT PROPERTIES</title>
121 <para>
122While font patterns may contain essentially any properties, there are some
123well known properties with associated types. Fontconfig uses some of these
124properties for font matching and font completion. Others are provided as a
125convenience for the applications rendering mechanism.
126 </para>
22671e25
KP
127 <programlisting>
128 Property Definitions
129
4f27c1c0 130 Property CPP Symbol Type Description
22671e25 131 ----------------------------------------------------
4f27c1c0
KP
132 family FC_FAMILY String Font family names
133 familylang FC_FAMILYLANG String Language cooresponding to
134 each family name
22671e25
KP
135 style FC_STYLE String Font style. Overrides weight
136 and slant
4f27c1c0
KP
137 stylelang FC_STYLELANG String Language cooresponding to
138 each style name
139 fullname FC_FULLNAME String Font face full name where
140 different from family and
141 family + style
142 fullnamelang FC_FULLNAMELANG String Language cooresponding to
143 each fullname
22671e25
KP
144 slant FC_SLANT Int Italic, oblique or roman
145 weight FC_WEIGHT Int Light, medium, demibold,
146 bold or black
147 size FC_SIZE Double Point size
148 aspect FC_ASPECT Double Stretches glyphs horizontally
149 before hinting
150 pixelsize FC_PIXEL_SIZE Double Pixel size
a05d257f
NL
151 spacing FC_SPACING Int Proportional, dual-width,
152 monospace or charcell
22671e25
KP
153 foundry FC_FOUNDRY String Font foundry name
154 antialias FC_ANTIALIAS Bool Whether glyphs can be
155 antialiased
156 hinting FC_HINTING Bool Whether the rasterizer should
157 use hinting
158 verticallayout FC_VERTICAL_LAYOUT Bool Use vertical layout
159 autohint FC_AUTOHINT Bool Use autohinter instead of
160 normal hinter
161 globaladvance FC_GLOBAL_ADVANCE Bool Use font global advance data
162 file FC_FILE String The filename holding the font
163 index FC_INDEX Int The index of the font within
164 the file
165 ftface FC_FT_FACE FT_Face Use the specified FreeType
166 face object
167 rasterizer FC_RASTERIZER String Which rasterizer is in use
168 outline FC_OUTLINE Bool Whether the glyphs are outlines
169 scalable FC_SCALABLE Bool Whether glyphs can be scaled
170 scale FC_SCALE Double Scale factor for point->pixel
171 conversions
172 dpi FC_DPI Double Target dots per inch
173 rgba FC_RGBA Int unknown, rgb, bgr, vrgb,
174 vbgr, none - subpixel geometry
175 minspace FC_MINSPACE Bool Eliminate leading from line
176 spacing
177 charset FC_CHARSET CharSet Unicode chars encoded by
178 the font
179 lang FC_LANG String List of RFC-3066-style
180 languages this font supports
181 </programlisting>
584ac89a 182 </sect2>
22dc6fc6 183</sect1>
39381776 184<sect1><title>Datatypes</title>
584ac89a
KP
185 <para>
186Fontconfig uses abstract datatypes to hide internal implementation details
187for most data structures. A few structures are exposed where appropriate.
188 </para>
39381776 189 <sect2><title>FcChar8, FcChar16, FcChar32, FcBool</title>
22671e25 190 <para>
584ac89a
KP
191These are primitive datatypes; the FcChar* types hold precisely the number
192of bits stated (if supported by the C implementation). FcBool holds
193one of two CPP symbols: FcFalse or FcTrue.
22671e25 194 </para>
39381776
KP
195 </sect2>
196 <sect2><title>FcMatrix</title>
584ac89a
KP
197 <para>
198An FcMatrix holds an affine transformation, usually used to reshape glyphs.
199A small set of matrix operations are provided to manipulate these.
200 <programlisting>
22671e25
KP
201 typedef struct _FcMatrix {
202 double xx, xy, yx, yy;
203 } FcMatrix;
584ac89a
KP
204 </programlisting>
205 </para>
39381776
KP
206 </sect2>
207 <sect2><title>FcCharSet</title>
584ac89a
KP
208 <para>
209An FcCharSet is an abstract type that holds the set of encoded unicode chars
210in a font. Operations to build and compare these sets are provided.
211 </para>
39381776
KP
212 </sect2>
213 <sect2><title>FcType</title>
584ac89a
KP
214 <para>
215Tags the kind of data stored in an FcValue.
22dc6fc6 216 </para>
39381776
KP
217 </sect2>
218 <sect2><title>FcValue</title>
584ac89a
KP
219 <para>
220An FcValue object holds a single value with one of a number of different
221types. The 'type' tag indicates which member is valid.
222 <programlisting>
22671e25
KP
223 typedef struct _FcValue {
224 FcType type;
225 union {
226 const FcChar8 *s;
227 int i;
228 FcBool b;
229 double d;
230 const FcMatrix *m;
231 const FcCharSet *c;
232 } u;
233 } FcValue;
234 </programlisting>
235 <programlisting>
236 FcValue Members
237
238 Type Union member Datatype
239 --------------------------------
240 FcTypeVoid (none) (none)
241 FcTypeInteger i int
242 FcTypeDouble d double
243 FcTypeString s char *
244 FcTypeBool b b
245 FcTypeMatrix m FcMatrix *
246 FcTypeCharSet c FcCharSet *
584ac89a 247 </programlisting>
22dc6fc6 248 </para>
39381776
KP
249 </sect2>
250 <sect2><title>FcPattern</title>
584ac89a
KP
251 <para>
252holds a set of names with associated value lists; each name refers to a
253property of a font. FcPatterns are used as inputs to the matching code as
254well as holding information about specific fonts. Each property can hold
255one or more values; conventionally all of the same type, although the
256interface doesn't demand that.
22dc6fc6 257 </para>
39381776
KP
258 </sect2>
259 <sect2><title>FcFontSet</title>
584ac89a
KP
260 <para>
261 <programlisting>
22671e25
KP
262 typedef struct _FcFontSet {
263 int nfont;
264 int sfont;
265 FcPattern **fonts;
266 } FcFontSet;
584ac89a
KP
267 </programlisting>
268An FcFontSet contains a list of FcPatterns. Internally fontconfig uses this
269data structure to hold sets of fonts. Externally, fontconfig returns the
270results of listing fonts in this format. 'nfont' holds the number of
271patterns in the 'fonts' array; 'sfont' is used to indicate the size of that
272array.
273 </para>
39381776
KP
274 </sect2>
275 <sect2><title>FcStrSet, FcStrList</title>
584ac89a
KP
276 <para>
277FcStrSet holds a list of strings that can be appended to and enumerated.
278Its unique characteristic is that the enumeration works even while strings
279are appended during enumeration. FcStrList is used during enumeration to
280safely and correctly walk the list of strings even while that list is edited
281in the middle of enumeration.
282 </para>
39381776
KP
283 </sect2>
284 <sect2><title>FcObjectSet</title>
584ac89a
KP
285 <para>
286 <programlisting>
22671e25
KP
287 typedef struct _FcObjectSet {
288 int nobject;
289 int sobject;
290 const char **objects;
291 } FcObjectSet;
584ac89a
KP
292 </programlisting>
293holds a set of names and is used to specify which fields from fonts are
294placed in the the list of returned patterns when listing fonts.
295 </para>
39381776
KP
296 </sect2>
297 <sect2><title>FcObjectType</title>
584ac89a
KP
298 <para>
299 <programlisting>
22671e25
KP
300 typedef struct _FcObjectType {
301 const char *object;
302 FcType type;
303 } FcObjectType;
584ac89a
KP
304 </programlisting>
305marks the type of a pattern element generated when parsing font names.
306Applications can add new object types so that font names may contain the new
307elements.
308 </para>
39381776
KP
309 </sect2>
310 <sect2><title>FcConstant</title>
584ac89a
KP
311 <para>
312 <programlisting>
22671e25
KP
313 typedef struct _FcConstant {
314 const FcChar8 *name;
315 const char *object;
316 int value;
317 } FcConstant;
584ac89a
KP
318 </programlisting>
319Provides for symbolic constants for new pattern elements. When 'name' is
320seen in a font name, an 'object' element is created with value 'value'.
321 </para>
39381776
KP
322 </sect2>
323 <sect2><title>FcBlanks</title>
584ac89a
KP
324 <para>
325holds a list of Unicode chars which are expected to be blank; unexpectedly
326blank chars are assumed to be invalid and are elided from the charset
327associated with the font.
328 </para>
39381776
KP
329 </sect2>
330 <sect2><title>FcFileCache</title>
584ac89a
KP
331 <para>
332holds the per-user cache information for use while loading the font
333database. This is built automatically for the current configuration when
334that is loaded. Applications must always pass '0' when one is requested.
335 </para>
39381776
KP
336 </sect2>
337 <sect2><title>FcConfig</title>
584ac89a
KP
338 <para>
339holds a complete configuration of the library; there is one default
340configuration, other can be constructed from XML data structures. All
341public entry points that need global data can take an optional FcConfig*
342argument; passing 0 uses the default configuration. FcConfig objects hold two
343sets of fonts, the first contains those specified by the configuration, the
344second set holds those added by the application at run-time. Interfaces
345that need to reference a particulat set use one of the FcSetName enumerated
346values.
347 </para>
39381776
KP
348 </sect2>
349 <sect2><title>FcSetName</title>
584ac89a
KP
350 <para>
351Specifies one of the two sets of fonts available in a configuration;
352FcSetSystem for those fonts specified in the configuration and
353FcSetApplication which holds fonts provided by the application.
354 </para>
39381776
KP
355 </sect2>
356 <sect2><title>FcResult</title>
584ac89a
KP
357 <para>
358Used as a return type for functions manipulating FcPattern objects.
22671e25
KP
359 <programlisting>
360 FcResult Values
361 Result Code Meaning
362 -----------------------------------------------------------
363 FcResultMatch Object exists with the specified ID
364 FcResultNoMatch Object doesn't exist at all
365 FcResultTypeMismatch Object exists, but the type doesn't match
366 FcResultNoId Object exists, but has fewer values
367 than specified
368 </programlisting>
584ac89a 369 </para>
39381776
KP
370 </sect2>
371 <sect2><title>FcAtomic</title>
584ac89a
KP
372 <para>
373Used for locking access to config files. Provides a safe way to update
374configuration files.
375 </para>
39381776 376 </sect2>
584ac89a
KP
377</sect1>
378<sect1><title>FUNCTIONS</title>
379 <para>
39381776
KP
380These are grouped by functionality, often using the main datatype being
381manipulated.
584ac89a 382 </para>
39381776 383 <sect2><title>Initialization</title>
584ac89a 384 <para>
39381776 385These functions provide some control over how the library is initialized.
584ac89a 386 </para>
39381776 387 &fcinit;
584ac89a
KP
388 </sect2>
389 <sect2><title>FcPattern</title>
390 <para>
391An FcPattern is an opaque type that holds both patterns to match against the
392available fonts, as well as the information about each font.
393 </para>
22671e25 394 &fcpattern;
584ac89a
KP
395 </sect2>
396 <sect2><title>FcFontSet</title>
397 <para>
398An FcFontSet simply holds a list of patterns; these are used to return the
399results of listing available fonts.
400 </para>
bfc2dc3a
KP
401 &fcfontset;
402 </sect2>
584ac89a
KP
403 <sect2><title>FcObjectSet</title>
404 <para>
405An FcObjectSet holds a list of pattern property names; it is used to
406indiciate which properties are to be returned in the patterns from
407FcFontList.
408 </para>
bfc2dc3a
KP
409 &fcobjectset;
410 </sect2>
39381776
KP
411 <sect2><title>FreeType specific functions</title>
412 <para>
413While the fontconfig library doesn't insist that FreeType be used as the
414rasterization mechanism for fonts, it does provide some convenience
415functions.
416 </para>
417 &fcfreetype;
418 </sect2>
419 <sect2><title>FcValue</title>
420 <para>
421FcValue is a structure containing a type tag and a union of all possible
422datatypes. The tag is an enum of type
423<emphasis>FcType</emphasis>
424and is intended to provide a measure of run-time
425typechecking, although that depends on careful programming.
426 </para>
427 &fcvalue;
428 </sect2>
429 <sect2><title>FcCharSet</title>
430 <para>
431An FcCharSet is a boolean array indicating a set of unicode chars. Those
432associated with a font are marked constant and cannot be edited.
433FcCharSets may be reference counted internally to reduce memory consumption;
434this may be visible to applications as the result of FcCharSetCopy may
435return it's argument, and that CharSet may remain unmodifiable.
436 </para>
437 &fccharset;
438 </sect2>
439 <sect2><title>FcMatrix</title>
440 <para>
441FcMatrix structures hold an affine transformation in matrix form.
442 </para>
443 &fcmatrix;
444 </sect2>
445 <sect2><title>FcConfig</title>
446 <para>
447An FcConfig object holds the internal representation of a configuration.
448There is a default configuration which applications may use by passing 0 to
449any function using the data within an FcConfig.
450 </para>
451 &fcconfig;
452 </sect2>
584ac89a
KP
453 <sect2><title>FcObjectType</title>
454 <para>
455Provides for applcation-specified font name object types so that new
456pattern elements can be generated from font names.
457 </para>
bfc2dc3a
KP
458 &fcobjecttype;
459 </sect2>
584ac89a
KP
460 <sect2><title>FcConstant</title>
461 <para>
462Provides for application-specified symbolic constants for font names.
463 </para>
bfc2dc3a
KP
464 &fcconstant;
465 </sect2>
584ac89a
KP
466 <sect2><title>FcBlanks</title>
467 <para>
468An FcBlanks object holds a list of Unicode chars which are expected to
469be blank when drawn. When scanning new fonts, any glyphs which are
470empty and not in this list will be assumed to be broken and not placed in
471the FcCharSet associated with the font. This provides a significantly more
472accurate CharSet for applications.
473 </para>
bfc2dc3a
KP
474 &fcblanks;
475 </sect2>
584ac89a
KP
476 <sect2><title>FcAtomic</title>
477 <para>
478These functions provide a safe way to update config files, allowing ongoing
479reading of the old config file while locked for writing and ensuring that a
480consistent and complete version of the config file is always available.
481 </para>
39381776
KP
482 &fcatomic;
483 </sect2>
584ac89a 484 <sect2><title>File and Directory routines</title>
39381776
KP
485 <para>
486These routines work with font files and directories, including font
487directory cache files.
8c87b429 488 </para>
39381776
KP
489 &fcfile;
490 </sect2>
584ac89a
KP
491 <sect2><title>FcStrSet and FcStrList</title>
492 <para>
493A data structure for enumerating strings, used to list directories while
494scanning the configuration as directories are added while scanning.
495 </para>
39381776
KP
496 &fcstrset;
497 </sect2>
584ac89a 498 <sect2><title>String utilities</title>
39381776
KP
499 <para>
500Fontconfig manipulates many UTF-8 strings represented with the FcChar8 type.
501These functions are exposed to help applications deal with these UTF-8
502strings in a locale-insensitive manner.
503 </para>
504 &fcstring;
505 </sect2>
584ac89a
KP
506</sect1>
507</article>