2003-03-07 08:12:51 +01:00
|
|
|
<!DOCTYPE article PUBLIC "-//OASIS//DTD DocBook V3.1//EN" [
|
2003-03-07 20:01:41 +01:00
|
|
|
<!ENTITY fcatomic SYSTEM "fcatomic.sgml">
|
|
|
|
<!ENTITY fcblanks SYSTEM "fcblanks.sgml">
|
2007-11-04 07:42:32 +01:00
|
|
|
<!ENTITY fccache SYSTEM "fccache.sgml">
|
2003-03-07 08:12:51 +01:00
|
|
|
<!ENTITY fccharset SYSTEM "fccharset.sgml">
|
2003-03-07 20:01:41 +01:00
|
|
|
<!ENTITY fcconfig SYSTEM "fcconfig.sgml">
|
|
|
|
<!ENTITY fcconstant SYSTEM "fcconstant.sgml">
|
2007-11-04 07:42:32 +01:00
|
|
|
<!ENTITY fcdircache SYSTEM "fcdircache.sgml">
|
2003-03-07 20:01:41 +01:00
|
|
|
<!ENTITY fcfile SYSTEM "fcfile.sgml">
|
2003-03-07 09:44:32 +01:00
|
|
|
<!ENTITY fcfontset SYSTEM "fcfontset.sgml">
|
2009-03-13 22:26:21 +01:00
|
|
|
<!ENTITY fcformat SYSTEM "fcformat.sgml">
|
2003-03-07 20:01:41 +01:00
|
|
|
<!ENTITY fcfreetype SYSTEM "fcfreetype.sgml">
|
|
|
|
<!ENTITY fcinit SYSTEM "fcinit.sgml">
|
2007-11-04 07:42:32 +01:00
|
|
|
<!ENTITY fclangset SYSTEM "fclangset.sgml">
|
2003-03-07 20:01:41 +01:00
|
|
|
<!ENTITY fcmatrix SYSTEM "fcmatrix.sgml">
|
2003-03-07 09:44:32 +01:00
|
|
|
<!ENTITY fcobjectset SYSTEM "fcobjectset.sgml">
|
|
|
|
<!ENTITY fcobjecttype SYSTEM "fcobjecttype.sgml">
|
2003-03-07 20:01:41 +01:00
|
|
|
<!ENTITY fcpattern SYSTEM "fcpattern.sgml">
|
2014-03-26 08:01:49 +01:00
|
|
|
<!ENTITY fcrange SYSTEM "fcrange.sgml">
|
2003-03-07 20:01:41 +01:00
|
|
|
<!ENTITY fcstring SYSTEM "fcstring.sgml">
|
|
|
|
<!ENTITY fcstrset SYSTEM "fcstrset.sgml">
|
|
|
|
<!ENTITY fcvalue SYSTEM "fcvalue.sgml">
|
2014-12-13 19:21:16 +01:00
|
|
|
<!ENTITY fcweight SYSTEM "fcweight.sgml">
|
2003-03-07 21:45:43 +01:00
|
|
|
<!ENTITY version SYSTEM "version.sgml">
|
2003-03-07 08:12:51 +01:00
|
|
|
]>
|
2003-03-01 03:23:52 +01:00
|
|
|
<!--
|
2008-08-13 09:30:23 +02:00
|
|
|
fontconfig/doc/local-fontconfig-devel.sgml
|
2022-12-13 08:05:41 +01:00
|
|
|
|
2004-12-07 02:14:46 +01:00
|
|
|
Copyright © 2003 Keith Packard
|
2022-12-13 08:05:41 +01:00
|
|
|
|
2003-03-01 03:23:52 +01:00
|
|
|
Permission to use, copy, modify, distribute, and sell this software and its
|
|
|
|
documentation for any purpose is hereby granted without fee, provided that
|
|
|
|
the above copyright notice appear in all copies and that both that
|
|
|
|
copyright notice and this permission notice appear in supporting
|
2010-11-10 22:45:42 +01:00
|
|
|
documentation, and that the name of the author(s) not be used in
|
2003-03-01 03:23:52 +01:00
|
|
|
advertising or publicity pertaining to distribution of the software without
|
2010-11-10 22:45:42 +01:00
|
|
|
specific, written prior permission. The authors make no
|
2003-03-01 03:23:52 +01:00
|
|
|
representations about the suitability of this software for any purpose. It
|
|
|
|
is provided "as is" without express or implied warranty.
|
2022-12-13 08:05:41 +01:00
|
|
|
|
2009-03-12 21:00:08 +01:00
|
|
|
THE AUTHOR(S) DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
|
2003-03-01 03:23:52 +01:00
|
|
|
INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO
|
2009-03-12 21:00:08 +01:00
|
|
|
EVENT SHALL THE AUTHOR(S) BE LIABLE FOR ANY SPECIAL, INDIRECT OR
|
2003-03-01 03:23:52 +01:00
|
|
|
CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE,
|
|
|
|
DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
|
|
|
|
TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
|
|
|
PERFORMANCE OF THIS SOFTWARE.
|
|
|
|
-->
|
|
|
|
<article>
|
2022-12-13 08:05:41 +01:00
|
|
|
<title>Fontconfig Developers Reference, Version &version; </title>
|
|
|
|
<artheader>
|
|
|
|
<author>
|
|
|
|
<firstname>Keith</firstname>
|
|
|
|
<surname>Packard</surname>
|
|
|
|
<affiliation><orgname>
|
|
|
|
HP Cambridge Research Lab
|
|
|
|
</orgname></affiliation>
|
|
|
|
</author>
|
|
|
|
<authorinitials>KRP</authorinitials>
|
|
|
|
<productname>Fontconfig</productname>
|
|
|
|
<productnumber>&version;</productnumber>
|
|
|
|
<LegalNotice>
|
|
|
|
<simpara>
|
2004-12-07 02:14:46 +01:00
|
|
|
Copyright © 2002 Keith Packard
|
2022-12-13 08:05:41 +01:00
|
|
|
</simpara><simpara>
|
2003-03-07 08:12:51 +01:00
|
|
|
Permission to use, copy, modify, distribute, and sell this software and its
|
|
|
|
documentation for any purpose is hereby granted without fee, provided that
|
|
|
|
the above copyright notice appear in all copies and that both that
|
|
|
|
copyright notice and this permission notice appear in supporting
|
2010-11-10 22:45:42 +01:00
|
|
|
documentation, and that the name of the author(s) not be used in
|
2003-03-07 08:12:51 +01:00
|
|
|
advertising or publicity pertaining to distribution of the software without
|
2010-11-10 22:45:42 +01:00
|
|
|
specific, written prior permission. The authors make no
|
2003-03-07 08:12:51 +01:00
|
|
|
representations about the suitability of this software for any purpose. It
|
|
|
|
is provided "as is" without express or implied warranty.
|
2022-12-13 08:05:41 +01:00
|
|
|
</simpara><simpara>
|
2009-03-12 21:00:08 +01:00
|
|
|
THE AUTHOR(S) DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
|
2003-03-07 08:12:51 +01:00
|
|
|
INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO
|
2009-03-12 21:00:08 +01:00
|
|
|
EVENT SHALL THE AUTHOR(S) BE LIABLE FOR ANY SPECIAL, INDIRECT OR
|
2003-03-07 08:12:51 +01:00
|
|
|
CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE,
|
|
|
|
DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
|
|
|
|
TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
|
|
|
PERFORMANCE OF THIS SOFTWARE.
|
2022-12-13 08:05:41 +01:00
|
|
|
</simpara>
|
|
|
|
</LegalNotice>
|
|
|
|
</artheader>
|
2003-03-01 03:23:52 +01:00
|
|
|
<sect1><title>DESCRIPTION</title>
|
|
|
|
<para>
|
|
|
|
Fontconfig is a library designed to provide system-wide font configuration,
|
|
|
|
customization and application access.
|
|
|
|
</para>
|
|
|
|
</sect1>
|
|
|
|
<sect1><title>FUNCTIONAL OVERVIEW</title>
|
|
|
|
<para>
|
|
|
|
Fontconfig contains two essential modules, the configuration module which
|
|
|
|
builds an internal configuration from XML files and the matching module
|
|
|
|
which accepts font patterns and returns the nearest matching font.
|
|
|
|
</para>
|
|
|
|
<sect2><title>FONT CONFIGURATION</title>
|
|
|
|
<para>
|
|
|
|
The configuration module consists of the FcConfig datatype, libexpat and
|
2011-03-11 23:43:42 +01:00
|
|
|
FcConfigParse which walks over an XML tree and amends a configuration with
|
2003-03-01 03:23:52 +01:00
|
|
|
data found within. From an external perspective, configuration of the
|
|
|
|
library consists of generating a valid XML tree and feeding that to
|
|
|
|
FcConfigParse. The only other mechanism provided to applications for
|
|
|
|
changing the running configuration is to add fonts and directories to the
|
2022-12-13 08:05:41 +01:00
|
|
|
list of application-provided font files.
|
2003-03-01 03:23:52 +01:00
|
|
|
</para><para>
|
|
|
|
The intent is to make font configurations relatively static, and shared by
|
|
|
|
as many applications as possible. It is hoped that this will lead to more
|
|
|
|
stable font selection when passing names from one application to another.
|
|
|
|
XML was chosen as a configuration file format because it provides a format
|
|
|
|
which is easy for external agents to edit while retaining the correct
|
|
|
|
structure and syntax.
|
|
|
|
</para><para>
|
|
|
|
Font configuration is separate from font matching; applications needing to
|
|
|
|
do their own matching can access the available fonts from the library and
|
|
|
|
perform private matching. The intent is to permit applications to pick and
|
|
|
|
choose appropriate functionality from the library instead of forcing them to
|
|
|
|
choose between this library and a private configuration mechanism. The hope
|
|
|
|
is that this will ensure that configuration of fonts for all applications
|
|
|
|
can be centralized in one place. Centralizing font configuration will
|
|
|
|
simplify and regularize font installation and customization.
|
|
|
|
</para>
|
|
|
|
</sect2>
|
|
|
|
<sect2>
|
|
|
|
<title>FONT PROPERTIES</title>
|
|
|
|
<para>
|
|
|
|
While font patterns may contain essentially any properties, there are some
|
|
|
|
well known properties with associated types. Fontconfig uses some of these
|
|
|
|
properties for font matching and font completion. Others are provided as a
|
2011-03-11 23:43:42 +01:00
|
|
|
convenience for the application's rendering mechanism.
|
2003-03-01 03:23:52 +01:00
|
|
|
</para>
|
2003-03-07 08:12:51 +01:00
|
|
|
<programlisting>
|
|
|
|
Property Definitions
|
|
|
|
|
2011-03-11 23:43:42 +01:00
|
|
|
Property C Preprocessor Symbol Type Description
|
2003-03-07 08:12:51 +01:00
|
|
|
----------------------------------------------------
|
2011-03-11 23:43:42 +01:00
|
|
|
family FC_FAMILY String Font family names
|
|
|
|
familylang FC_FAMILYLANG String Language corresponding to
|
|
|
|
each family name
|
|
|
|
style FC_STYLE String Font style. Overrides weight
|
|
|
|
and slant
|
|
|
|
stylelang FC_STYLELANG String Language corresponding to
|
|
|
|
each style name
|
|
|
|
fullname FC_FULLNAME String Font face full name where
|
|
|
|
different from family and
|
|
|
|
family + style
|
|
|
|
fullnamelang FC_FULLNAMELANG String Language corresponding to
|
|
|
|
each fullname
|
|
|
|
slant FC_SLANT Int Italic, oblique or roman
|
|
|
|
weight FC_WEIGHT Int Light, medium, demibold,
|
|
|
|
bold or black
|
|
|
|
width FC_WIDTH Int Condensed, normal or expanded
|
2019-07-23 09:00:43 +02:00
|
|
|
size FC_SIZE Double Point size
|
2011-03-11 23:43:42 +01:00
|
|
|
aspect FC_ASPECT Double Stretches glyphs horizontally
|
|
|
|
before hinting
|
|
|
|
pixelsize FC_PIXEL_SIZE Double Pixel size
|
|
|
|
spacing FC_SPACING Int Proportional, dual-width,
|
|
|
|
monospace or charcell
|
|
|
|
foundry FC_FOUNDRY String Font foundry name
|
|
|
|
antialias FC_ANTIALIAS Bool Whether glyphs can be
|
|
|
|
antialiased
|
2019-07-23 09:00:43 +02:00
|
|
|
hintstyle FC_HINT_STYLE Int Automatic hinting style
|
2011-03-11 23:43:42 +01:00
|
|
|
hinting FC_HINTING Bool Whether the rasterizer should
|
|
|
|
use hinting
|
|
|
|
verticallayout FC_VERTICAL_LAYOUT Bool Use vertical layout
|
|
|
|
autohint FC_AUTOHINT Bool Use autohinter instead of
|
|
|
|
normal hinter
|
2012-06-11 07:14:41 +02:00
|
|
|
globaladvance FC_GLOBAL_ADVANCE Bool Use font global advance data (deprecated)
|
2011-03-11 23:43:42 +01:00
|
|
|
file FC_FILE String The filename holding the font
|
2019-02-19 01:40:32 +01:00
|
|
|
relative to the config's sysroot
|
2011-03-11 23:43:42 +01:00
|
|
|
index FC_INDEX Int The index of the font within
|
|
|
|
the file
|
|
|
|
ftface FC_FT_FACE FT_Face Use the specified FreeType
|
|
|
|
face object
|
2013-09-10 10:45:11 +02:00
|
|
|
rasterizer FC_RASTERIZER String Which rasterizer is in use (deprecated)
|
2011-03-11 23:43:42 +01:00
|
|
|
outline FC_OUTLINE Bool Whether the glyphs are outlines
|
2023-06-12 09:51:26 +02:00
|
|
|
scalable FC_SCALABLE Bool Whether the glyphs are outlines or have color
|
2011-03-11 23:43:42 +01:00
|
|
|
dpi FC_DPI Double Target dots per inch
|
|
|
|
rgba FC_RGBA Int unknown, rgb, bgr, vrgb,
|
|
|
|
vbgr, none - subpixel geometry
|
2019-07-23 09:00:43 +02:00
|
|
|
scale FC_SCALE Double Scale factor for point->pixel
|
|
|
|
conversions (deprecated)
|
2011-03-11 23:43:42 +01:00
|
|
|
minspace FC_MINSPACE Bool Eliminate leading from line
|
|
|
|
spacing
|
2023-05-17 07:18:52 +02:00
|
|
|
matrix FC_MATRIX Matrix Hold an affine transformation
|
2011-03-11 23:43:42 +01:00
|
|
|
charset FC_CHARSET CharSet Unicode chars encoded by
|
|
|
|
the font
|
|
|
|
lang FC_LANG LangSet Set of RFC-3066-style
|
|
|
|
languages this font supports
|
|
|
|
fontversion FC_FONTVERSION Int Version number of the font
|
|
|
|
capability FC_CAPABILITY String List of layout capabilities in
|
|
|
|
the font
|
2015-01-06 08:37:18 +01:00
|
|
|
fontformat FC_FONTFORMAT String String name of the font format
|
2011-03-11 23:43:42 +01:00
|
|
|
embolden FC_EMBOLDEN Bool Rasterizer should
|
|
|
|
synthetically embolden the font
|
2015-01-06 08:37:18 +01:00
|
|
|
embeddedbitmap FC_EMBEDDED_BITMAP Bool Use the embedded bitmap instead
|
|
|
|
of the outline
|
|
|
|
decorative FC_DECORATIVE Bool Whether the style is a decorative
|
|
|
|
variant
|
2019-07-23 09:00:43 +02:00
|
|
|
lcdfilter FC_LCD_FILTER Int Type of LCD filter
|
2012-03-26 09:34:34 +02:00
|
|
|
namelang FC_NAMELANG String Language name to be used for the
|
|
|
|
default value of familylang,
|
|
|
|
stylelang and fullnamelang
|
2019-07-23 09:00:43 +02:00
|
|
|
fontfeatures FC_FONT_FEATURES String List of extra feature tags in
|
|
|
|
OpenType to be enabled
|
2013-01-16 03:41:26 +01:00
|
|
|
prgname FC_PRGNAME String Name of the running program
|
2013-04-10 04:14:39 +02:00
|
|
|
hash FC_HASH String SHA256 hash value of the font data
|
2014-06-10 03:53:01 +02:00
|
|
|
with "sha256:" prefix (deprecated)
|
2013-04-10 04:14:39 +02:00
|
|
|
postscriptname FC_POSTSCRIPT_NAME String Font name in PostScript
|
2019-07-23 09:00:43 +02:00
|
|
|
color FC_COLOR Bool Whether any glyphs have color
|
2023-05-17 07:11:22 +02:00
|
|
|
symbol FC_SYMBOL Bool Whether font uses MS symbol-font encoding
|
2019-07-23 09:00:43 +02:00
|
|
|
fontvariations FC_FONT_VARIATIONS String comma-separated string of axes in variable font
|
|
|
|
variable FC_VARIABLE Bool Whether font is Variable Font
|
2019-07-29 11:38:51 +02:00
|
|
|
fonthashint FC_FONT_HAS_HINT Bool Whether font has hinting
|
2020-05-25 11:22:18 +02:00
|
|
|
order FC_ORDER Int Order number of the font
|
2023-05-17 07:18:52 +02:00
|
|
|
desktop FC_DESKTOP_NAME String Current desktop name
|
2023-05-30 12:00:02 +02:00
|
|
|
namedinstance FC_NAMED_INSTANCE Bool Whether font is a named instance
|
2023-08-03 10:08:23 +02:00
|
|
|
fontwarapper FC_FONT_WRAPPER String The font wrapper format
|
2003-03-07 08:12:51 +01:00
|
|
|
</programlisting>
|
2003-03-01 03:23:52 +01:00
|
|
|
</sect2>
|
2003-03-03 02:13:11 +01:00
|
|
|
</sect1>
|
2003-03-07 20:01:41 +01:00
|
|
|
<sect1><title>Datatypes</title>
|
2003-03-01 03:23:52 +01:00
|
|
|
<para>
|
2011-03-11 23:43:42 +01:00
|
|
|
Fontconfig uses abstract data types to hide internal implementation details
|
2003-03-01 03:23:52 +01:00
|
|
|
for most data structures. A few structures are exposed where appropriate.
|
|
|
|
</para>
|
2003-03-07 20:01:41 +01:00
|
|
|
<sect2><title>FcChar8, FcChar16, FcChar32, FcBool</title>
|
2003-03-07 08:12:51 +01:00
|
|
|
<para>
|
2011-03-11 23:43:42 +01:00
|
|
|
These are primitive data types; the FcChar* types hold precisely the number
|
2003-03-01 03:23:52 +01:00
|
|
|
of bits stated (if supported by the C implementation). FcBool holds
|
2011-03-11 23:43:42 +01:00
|
|
|
one of two C preprocessor symbols: FcFalse or FcTrue.
|
2003-03-07 08:12:51 +01:00
|
|
|
</para>
|
2003-03-07 20:01:41 +01:00
|
|
|
</sect2>
|
|
|
|
<sect2><title>FcMatrix</title>
|
2003-03-01 03:23:52 +01:00
|
|
|
<para>
|
|
|
|
An FcMatrix holds an affine transformation, usually used to reshape glyphs.
|
|
|
|
A small set of matrix operations are provided to manipulate these.
|
|
|
|
<programlisting>
|
2003-03-07 08:12:51 +01:00
|
|
|
typedef struct _FcMatrix {
|
|
|
|
double xx, xy, yx, yy;
|
|
|
|
} FcMatrix;
|
2003-03-01 03:23:52 +01:00
|
|
|
</programlisting>
|
|
|
|
</para>
|
2003-03-07 20:01:41 +01:00
|
|
|
</sect2>
|
|
|
|
<sect2><title>FcCharSet</title>
|
2003-03-01 03:23:52 +01:00
|
|
|
<para>
|
2011-03-11 23:43:42 +01:00
|
|
|
An FcCharSet is an abstract type that holds the set of encoded Unicode chars
|
2003-03-01 03:23:52 +01:00
|
|
|
in a font. Operations to build and compare these sets are provided.
|
|
|
|
</para>
|
2003-03-07 20:01:41 +01:00
|
|
|
</sect2>
|
2007-11-04 06:23:28 +01:00
|
|
|
<sect2><title>FcLangSet</title>
|
|
|
|
<para>
|
|
|
|
An FcLangSet is an abstract type that holds the set of languages supported
|
|
|
|
by a font. Operations to build and compare these sets are provided. These
|
|
|
|
are computed for a font based on orthographic information built into the
|
|
|
|
fontconfig library. Fontconfig has orthographies for all of the ISO 639-1
|
|
|
|
languages except for MS, NA, PA, PS, QU, RN, RW, SD, SG, SN, SU and ZA. If
|
|
|
|
you have orthographic information for any of these languages, please submit
|
|
|
|
them.
|
|
|
|
</para>
|
|
|
|
</sect2>
|
|
|
|
<sect2><title>FcLangResult</title>
|
|
|
|
<para>
|
|
|
|
An FcLangResult is an enumeration used to return the results of comparing
|
|
|
|
two language strings or FcLangSet objects. FcLangEqual means the
|
|
|
|
objects match language and territory. FcLangDifferentTerritory means
|
|
|
|
the objects match in language but differ in territory.
|
|
|
|
FcLangDifferentLang means the objects differ in language.
|
|
|
|
</para>
|
|
|
|
</sect2>
|
2003-03-07 20:01:41 +01:00
|
|
|
<sect2><title>FcType</title>
|
2003-03-01 03:23:52 +01:00
|
|
|
<para>
|
|
|
|
Tags the kind of data stored in an FcValue.
|
2003-03-03 02:13:11 +01:00
|
|
|
</para>
|
2003-03-07 20:01:41 +01:00
|
|
|
</sect2>
|
|
|
|
<sect2><title>FcValue</title>
|
2003-03-01 03:23:52 +01:00
|
|
|
<para>
|
|
|
|
An FcValue object holds a single value with one of a number of different
|
|
|
|
types. The 'type' tag indicates which member is valid.
|
|
|
|
<programlisting>
|
2003-03-07 08:12:51 +01:00
|
|
|
typedef struct _FcValue {
|
|
|
|
FcType type;
|
|
|
|
union {
|
|
|
|
const FcChar8 *s;
|
|
|
|
int i;
|
|
|
|
FcBool b;
|
|
|
|
double d;
|
|
|
|
const FcMatrix *m;
|
|
|
|
const FcCharSet *c;
|
2022-12-13 08:05:41 +01:00
|
|
|
void *f;
|
|
|
|
const FcLangSet *l;
|
|
|
|
const FcRange *r;
|
2003-03-07 08:12:51 +01:00
|
|
|
} u;
|
|
|
|
} FcValue;
|
|
|
|
</programlisting>
|
|
|
|
<programlisting>
|
|
|
|
FcValue Members
|
|
|
|
|
|
|
|
Type Union member Datatype
|
|
|
|
--------------------------------
|
|
|
|
FcTypeVoid (none) (none)
|
|
|
|
FcTypeInteger i int
|
|
|
|
FcTypeDouble d double
|
2007-11-04 07:03:11 +01:00
|
|
|
FcTypeString s FcChar8 *
|
2003-03-07 08:12:51 +01:00
|
|
|
FcTypeBool b b
|
|
|
|
FcTypeMatrix m FcMatrix *
|
|
|
|
FcTypeCharSet c FcCharSet *
|
2022-12-13 08:05:41 +01:00
|
|
|
FcTypeFTFace f void * (FT_Face)
|
|
|
|
FcTypeLangSet l FcLangSet *
|
|
|
|
FcTypeRange r FcRange *
|
2003-03-01 03:23:52 +01:00
|
|
|
</programlisting>
|
2003-03-03 02:13:11 +01:00
|
|
|
</para>
|
2003-03-07 20:01:41 +01:00
|
|
|
</sect2>
|
2019-07-23 09:00:43 +02:00
|
|
|
<sect2><title>FcPattern, FcPatternIter</title>
|
2003-03-01 03:23:52 +01:00
|
|
|
<para>
|
2019-07-23 09:00:43 +02:00
|
|
|
An FcPattern holds a set of names with associated value lists; each name refers to a
|
2003-03-01 03:23:52 +01:00
|
|
|
property of a font. FcPatterns are used as inputs to the matching code as
|
|
|
|
well as holding information about specific fonts. Each property can hold
|
|
|
|
one or more values; conventionally all of the same type, although the
|
2019-07-23 09:00:43 +02:00
|
|
|
interface doesn't demand that. An FcPatternIter is used during iteration to
|
|
|
|
access properties in FcPattern.
|
2003-03-03 02:13:11 +01:00
|
|
|
</para>
|
2003-03-07 20:01:41 +01:00
|
|
|
</sect2>
|
|
|
|
<sect2><title>FcFontSet</title>
|
2003-03-01 03:23:52 +01:00
|
|
|
<para>
|
|
|
|
<programlisting>
|
2003-03-07 08:12:51 +01:00
|
|
|
typedef struct _FcFontSet {
|
|
|
|
int nfont;
|
|
|
|
int sfont;
|
|
|
|
FcPattern **fonts;
|
|
|
|
} FcFontSet;
|
2003-03-01 03:23:52 +01:00
|
|
|
</programlisting>
|
|
|
|
An FcFontSet contains a list of FcPatterns. Internally fontconfig uses this
|
|
|
|
data structure to hold sets of fonts. Externally, fontconfig returns the
|
|
|
|
results of listing fonts in this format. 'nfont' holds the number of
|
|
|
|
patterns in the 'fonts' array; 'sfont' is used to indicate the size of that
|
|
|
|
array.
|
|
|
|
</para>
|
2003-03-07 20:01:41 +01:00
|
|
|
</sect2>
|
|
|
|
<sect2><title>FcStrSet, FcStrList</title>
|
2003-03-01 03:23:52 +01:00
|
|
|
<para>
|
|
|
|
FcStrSet holds a list of strings that can be appended to and enumerated.
|
|
|
|
Its unique characteristic is that the enumeration works even while strings
|
|
|
|
are appended during enumeration. FcStrList is used during enumeration to
|
|
|
|
safely and correctly walk the list of strings even while that list is edited
|
|
|
|
in the middle of enumeration.
|
|
|
|
</para>
|
2003-03-07 20:01:41 +01:00
|
|
|
</sect2>
|
|
|
|
<sect2><title>FcObjectSet</title>
|
2003-03-01 03:23:52 +01:00
|
|
|
<para>
|
|
|
|
<programlisting>
|
2003-03-07 08:12:51 +01:00
|
|
|
typedef struct _FcObjectSet {
|
|
|
|
int nobject;
|
|
|
|
int sobject;
|
|
|
|
const char **objects;
|
|
|
|
} FcObjectSet;
|
2003-03-01 03:23:52 +01:00
|
|
|
</programlisting>
|
|
|
|
holds a set of names and is used to specify which fields from fonts are
|
|
|
|
placed in the the list of returned patterns when listing fonts.
|
|
|
|
</para>
|
2003-03-07 20:01:41 +01:00
|
|
|
</sect2>
|
|
|
|
<sect2><title>FcObjectType</title>
|
2003-03-01 03:23:52 +01:00
|
|
|
<para>
|
|
|
|
<programlisting>
|
2003-03-07 08:12:51 +01:00
|
|
|
typedef struct _FcObjectType {
|
|
|
|
const char *object;
|
|
|
|
FcType type;
|
|
|
|
} FcObjectType;
|
2003-03-01 03:23:52 +01:00
|
|
|
</programlisting>
|
|
|
|
marks the type of a pattern element generated when parsing font names.
|
|
|
|
Applications can add new object types so that font names may contain the new
|
|
|
|
elements.
|
|
|
|
</para>
|
2003-03-07 20:01:41 +01:00
|
|
|
</sect2>
|
|
|
|
<sect2><title>FcConstant</title>
|
2003-03-01 03:23:52 +01:00
|
|
|
<para>
|
|
|
|
<programlisting>
|
2003-03-07 08:12:51 +01:00
|
|
|
typedef struct _FcConstant {
|
|
|
|
const FcChar8 *name;
|
|
|
|
const char *object;
|
|
|
|
int value;
|
|
|
|
} FcConstant;
|
2003-03-01 03:23:52 +01:00
|
|
|
</programlisting>
|
|
|
|
Provides for symbolic constants for new pattern elements. When 'name' is
|
|
|
|
seen in a font name, an 'object' element is created with value 'value'.
|
|
|
|
</para>
|
2003-03-07 20:01:41 +01:00
|
|
|
</sect2>
|
|
|
|
<sect2><title>FcBlanks</title>
|
2003-03-01 03:23:52 +01:00
|
|
|
<para>
|
|
|
|
holds a list of Unicode chars which are expected to be blank; unexpectedly
|
|
|
|
blank chars are assumed to be invalid and are elided from the charset
|
|
|
|
associated with the font.
|
|
|
|
</para>
|
2017-09-12 23:08:08 +02:00
|
|
|
<para>
|
|
|
|
FcBlanks is deprecated and should not be used in newly written code.
|
|
|
|
It is still accepted by some functions for compatibility with
|
|
|
|
older code but will be removed in the future.
|
|
|
|
</para>
|
2003-03-07 20:01:41 +01:00
|
|
|
</sect2>
|
|
|
|
<sect2><title>FcFileCache</title>
|
2003-03-01 03:23:52 +01:00
|
|
|
<para>
|
|
|
|
holds the per-user cache information for use while loading the font
|
|
|
|
database. This is built automatically for the current configuration when
|
|
|
|
that is loaded. Applications must always pass '0' when one is requested.
|
|
|
|
</para>
|
2003-03-07 20:01:41 +01:00
|
|
|
</sect2>
|
|
|
|
<sect2><title>FcConfig</title>
|
2003-03-01 03:23:52 +01:00
|
|
|
<para>
|
|
|
|
holds a complete configuration of the library; there is one default
|
|
|
|
configuration, other can be constructed from XML data structures. All
|
|
|
|
public entry points that need global data can take an optional FcConfig*
|
|
|
|
argument; passing 0 uses the default configuration. FcConfig objects hold two
|
|
|
|
sets of fonts, the first contains those specified by the configuration, the
|
|
|
|
second set holds those added by the application at run-time. Interfaces
|
2011-03-11 23:43:42 +01:00
|
|
|
that need to reference a particular set use one of the FcSetName enumerated
|
2003-03-01 03:23:52 +01:00
|
|
|
values.
|
|
|
|
</para>
|
2003-03-07 20:01:41 +01:00
|
|
|
</sect2>
|
|
|
|
<sect2><title>FcSetName</title>
|
2003-03-01 03:23:52 +01:00
|
|
|
<para>
|
|
|
|
Specifies one of the two sets of fonts available in a configuration;
|
|
|
|
FcSetSystem for those fonts specified in the configuration and
|
|
|
|
FcSetApplication which holds fonts provided by the application.
|
|
|
|
</para>
|
2003-03-07 20:01:41 +01:00
|
|
|
</sect2>
|
|
|
|
<sect2><title>FcResult</title>
|
2003-03-01 03:23:52 +01:00
|
|
|
<para>
|
|
|
|
Used as a return type for functions manipulating FcPattern objects.
|
2003-03-07 08:12:51 +01:00
|
|
|
<programlisting>
|
|
|
|
FcResult Values
|
|
|
|
Result Code Meaning
|
|
|
|
-----------------------------------------------------------
|
|
|
|
FcResultMatch Object exists with the specified ID
|
|
|
|
FcResultNoMatch Object doesn't exist at all
|
|
|
|
FcResultTypeMismatch Object exists, but the type doesn't match
|
|
|
|
FcResultNoId Object exists, but has fewer values
|
|
|
|
than specified
|
2011-03-11 23:43:42 +01:00
|
|
|
FcResultOutOfMemory malloc failed
|
2003-03-07 08:12:51 +01:00
|
|
|
</programlisting>
|
2003-03-01 03:23:52 +01:00
|
|
|
</para>
|
2003-03-07 20:01:41 +01:00
|
|
|
</sect2>
|
|
|
|
<sect2><title>FcAtomic</title>
|
2003-03-01 03:23:52 +01:00
|
|
|
<para>
|
2011-03-11 23:43:42 +01:00
|
|
|
Used for locking access to configuration files. Provides a safe way to update
|
2003-03-01 03:23:52 +01:00
|
|
|
configuration files.
|
|
|
|
</para>
|
2003-03-07 20:01:41 +01:00
|
|
|
</sect2>
|
2007-11-04 07:42:32 +01:00
|
|
|
<sect2><title>FcCache</title>
|
|
|
|
<para>
|
|
|
|
Holds information about the fonts contained in a single directory. Normal
|
|
|
|
applications need not worry about this as caches for font access are
|
|
|
|
automatically managed by the library. Applications dealing with cache
|
|
|
|
management may want to use some of these objects in their work, however the
|
|
|
|
included 'fc-cache' program generally suffices for all of that.
|
|
|
|
</para>
|
|
|
|
</sect2>
|
2003-03-01 03:23:52 +01:00
|
|
|
</sect1>
|
|
|
|
<sect1><title>FUNCTIONS</title>
|
|
|
|
<para>
|
2011-03-11 23:43:42 +01:00
|
|
|
These are grouped by functionality, often using the main data type being
|
2003-03-07 20:01:41 +01:00
|
|
|
manipulated.
|
2003-03-01 03:23:52 +01:00
|
|
|
</para>
|
2003-03-07 20:01:41 +01:00
|
|
|
<sect2><title>Initialization</title>
|
2003-03-01 03:23:52 +01:00
|
|
|
<para>
|
2003-03-07 20:01:41 +01:00
|
|
|
These functions provide some control over how the library is initialized.
|
2003-03-01 03:23:52 +01:00
|
|
|
</para>
|
2003-03-07 20:01:41 +01:00
|
|
|
&fcinit;
|
2003-03-01 03:23:52 +01:00
|
|
|
</sect2>
|
|
|
|
<sect2><title>FcPattern</title>
|
|
|
|
<para>
|
|
|
|
An FcPattern is an opaque type that holds both patterns to match against the
|
|
|
|
available fonts, as well as the information about each font.
|
|
|
|
</para>
|
2003-03-07 08:12:51 +01:00
|
|
|
&fcpattern;
|
2009-03-13 22:26:21 +01:00
|
|
|
&fcformat;
|
2003-03-01 03:23:52 +01:00
|
|
|
</sect2>
|
|
|
|
<sect2><title>FcFontSet</title>
|
|
|
|
<para>
|
|
|
|
An FcFontSet simply holds a list of patterns; these are used to return the
|
|
|
|
results of listing available fonts.
|
|
|
|
</para>
|
2003-03-07 09:44:32 +01:00
|
|
|
&fcfontset;
|
|
|
|
</sect2>
|
2003-03-01 03:23:52 +01:00
|
|
|
<sect2><title>FcObjectSet</title>
|
|
|
|
<para>
|
|
|
|
An FcObjectSet holds a list of pattern property names; it is used to
|
2011-03-11 23:43:42 +01:00
|
|
|
indicate which properties are to be returned in the patterns from
|
2003-03-01 03:23:52 +01:00
|
|
|
FcFontList.
|
|
|
|
</para>
|
2003-03-07 09:44:32 +01:00
|
|
|
&fcobjectset;
|
|
|
|
</sect2>
|
2003-03-07 20:01:41 +01:00
|
|
|
<sect2><title>FreeType specific functions</title>
|
|
|
|
<para>
|
|
|
|
While the fontconfig library doesn't insist that FreeType be used as the
|
|
|
|
rasterization mechanism for fonts, it does provide some convenience
|
|
|
|
functions.
|
|
|
|
</para>
|
|
|
|
&fcfreetype;
|
|
|
|
</sect2>
|
|
|
|
<sect2><title>FcValue</title>
|
|
|
|
<para>
|
|
|
|
FcValue is a structure containing a type tag and a union of all possible
|
2022-12-13 08:05:41 +01:00
|
|
|
datatypes. The tag is an enum of type
|
2003-03-07 20:01:41 +01:00
|
|
|
<emphasis>FcType</emphasis>
|
|
|
|
and is intended to provide a measure of run-time
|
|
|
|
typechecking, although that depends on careful programming.
|
|
|
|
</para>
|
|
|
|
&fcvalue;
|
|
|
|
</sect2>
|
|
|
|
<sect2><title>FcCharSet</title>
|
|
|
|
<para>
|
2011-03-11 23:43:42 +01:00
|
|
|
An FcCharSet is a boolean array indicating a set of Unicode chars. Those
|
2003-03-07 20:01:41 +01:00
|
|
|
associated with a font are marked constant and cannot be edited.
|
|
|
|
FcCharSets may be reference counted internally to reduce memory consumption;
|
|
|
|
this may be visible to applications as the result of FcCharSetCopy may
|
|
|
|
return it's argument, and that CharSet may remain unmodifiable.
|
|
|
|
</para>
|
|
|
|
&fccharset;
|
|
|
|
</sect2>
|
2007-11-04 07:42:32 +01:00
|
|
|
<sect2><title>FcLangSet</title>
|
|
|
|
<para>
|
|
|
|
An FcLangSet is a set of language names (each of which include language and
|
|
|
|
an optional territory). They are used when selecting fonts to indicate which
|
|
|
|
languages the fonts need to support. Each font is marked, using language
|
|
|
|
orthography information built into fontconfig, with the set of supported
|
|
|
|
languages.
|
|
|
|
</para>
|
|
|
|
&fclangset;
|
|
|
|
</sect2>
|
2003-03-07 20:01:41 +01:00
|
|
|
<sect2><title>FcMatrix</title>
|
|
|
|
<para>
|
|
|
|
FcMatrix structures hold an affine transformation in matrix form.
|
|
|
|
</para>
|
|
|
|
&fcmatrix;
|
|
|
|
</sect2>
|
2014-03-26 08:01:49 +01:00
|
|
|
<sect2><title>FcRange</title>
|
|
|
|
<para>
|
|
|
|
An FcRange holds two variables to indicate a range in between.
|
|
|
|
</para>
|
|
|
|
&fcrange;
|
|
|
|
</sect2>
|
2003-03-07 20:01:41 +01:00
|
|
|
<sect2><title>FcConfig</title>
|
|
|
|
<para>
|
|
|
|
An FcConfig object holds the internal representation of a configuration.
|
|
|
|
There is a default configuration which applications may use by passing 0 to
|
|
|
|
any function using the data within an FcConfig.
|
|
|
|
</para>
|
|
|
|
&fcconfig;
|
|
|
|
</sect2>
|
2003-03-01 03:23:52 +01:00
|
|
|
<sect2><title>FcObjectType</title>
|
|
|
|
<para>
|
2011-03-11 23:43:42 +01:00
|
|
|
Provides for application-specified font name object types so that new
|
2003-03-01 03:23:52 +01:00
|
|
|
pattern elements can be generated from font names.
|
|
|
|
</para>
|
2003-03-07 09:44:32 +01:00
|
|
|
&fcobjecttype;
|
|
|
|
</sect2>
|
2003-03-01 03:23:52 +01:00
|
|
|
<sect2><title>FcConstant</title>
|
|
|
|
<para>
|
|
|
|
Provides for application-specified symbolic constants for font names.
|
|
|
|
</para>
|
2003-03-07 09:44:32 +01:00
|
|
|
&fcconstant;
|
|
|
|
</sect2>
|
2014-12-13 19:21:16 +01:00
|
|
|
<sect2><title>FcWeight</title>
|
|
|
|
<para>
|
|
|
|
Maps weights to and from OpenType weights.
|
|
|
|
</para>
|
|
|
|
&fcweight;
|
|
|
|
</sect2>
|
2003-03-01 03:23:52 +01:00
|
|
|
<sect2><title>FcBlanks</title>
|
|
|
|
<para>
|
|
|
|
An FcBlanks object holds a list of Unicode chars which are expected to
|
|
|
|
be blank when drawn. When scanning new fonts, any glyphs which are
|
|
|
|
empty and not in this list will be assumed to be broken and not placed in
|
|
|
|
the FcCharSet associated with the font. This provides a significantly more
|
|
|
|
accurate CharSet for applications.
|
|
|
|
</para>
|
2017-09-12 23:08:08 +02:00
|
|
|
<para>
|
|
|
|
FcBlanks is deprecated and should not be used in newly written code.
|
|
|
|
It is still accepted by some functions for compatibility with
|
|
|
|
older code but will be removed in the future.
|
|
|
|
</para>
|
2003-03-07 09:44:32 +01:00
|
|
|
&fcblanks;
|
|
|
|
</sect2>
|
2003-03-01 03:23:52 +01:00
|
|
|
<sect2><title>FcAtomic</title>
|
|
|
|
<para>
|
2011-03-11 23:43:42 +01:00
|
|
|
These functions provide a safe way to update configuration files, allowing ongoing
|
|
|
|
reading of the old configuration file while locked for writing and ensuring that a
|
|
|
|
consistent and complete version of the configuration file is always available.
|
2003-03-01 03:23:52 +01:00
|
|
|
</para>
|
2003-03-07 20:01:41 +01:00
|
|
|
&fcatomic;
|
|
|
|
</sect2>
|
2003-03-01 03:23:52 +01:00
|
|
|
<sect2><title>File and Directory routines</title>
|
2003-03-07 20:01:41 +01:00
|
|
|
<para>
|
|
|
|
These routines work with font files and directories, including font
|
|
|
|
directory cache files.
|
2003-04-23 06:09:28 +02:00
|
|
|
</para>
|
2003-03-07 20:01:41 +01:00
|
|
|
&fcfile;
|
2007-11-04 07:42:32 +01:00
|
|
|
&fcdircache;
|
|
|
|
</sect2>
|
|
|
|
<sect2><title>FcCache routines</title>
|
|
|
|
<para>
|
|
|
|
These routines work with font directory caches, accessing their contents in
|
|
|
|
limited ways. It is not expected that normal applications will need to use
|
|
|
|
these functions.
|
|
|
|
</para>
|
|
|
|
&fccache;
|
2003-03-07 20:01:41 +01:00
|
|
|
</sect2>
|
2003-03-01 03:23:52 +01:00
|
|
|
<sect2><title>FcStrSet and FcStrList</title>
|
|
|
|
<para>
|
|
|
|
A data structure for enumerating strings, used to list directories while
|
|
|
|
scanning the configuration as directories are added while scanning.
|
|
|
|
</para>
|
2003-03-07 20:01:41 +01:00
|
|
|
&fcstrset;
|
|
|
|
</sect2>
|
2003-03-01 03:23:52 +01:00
|
|
|
<sect2><title>String utilities</title>
|
2003-03-07 20:01:41 +01:00
|
|
|
<para>
|
|
|
|
Fontconfig manipulates many UTF-8 strings represented with the FcChar8 type.
|
|
|
|
These functions are exposed to help applications deal with these UTF-8
|
|
|
|
strings in a locale-insensitive manner.
|
|
|
|
</para>
|
|
|
|
&fcstring;
|
|
|
|
</sect2>
|
2003-03-01 03:23:52 +01:00
|
|
|
</sect1>
|
|
|
|
</article>
|