2 * fontconfig/src/fcint.h
4 * Copyright © 2000 Keith Packard
6 * Permission to use, copy, modify, distribute, and sell this software and its
7 * documentation for any purpose is hereby granted without fee, provided that
8 * the above copyright notice appear in all copies and that both that
9 * copyright notice and this permission notice appear in supporting
10 * documentation, and that the name of the author(s) not be used in
11 * advertising or publicity pertaining to distribution of the software without
12 * specific, written prior permission. The authors make no
13 * representations about the suitability of this software for any purpose. It
14 * is provided "as is" without express or implied warranty.
16 * THE AUTHOR(S) DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
17 * INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO
18 * EVENT SHALL THE AUTHOR(S) BE LIABLE FOR ANY SPECIAL, INDIRECT OR
19 * CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE,
20 * DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
21 * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
22 * PERFORMANCE OF THIS SOFTWARE.
34 #ifdef HAVE_INTTYPES_H
36 #elif defined(HAVE_STDINT_H)
39 #error missing C99 integer data types
46 #include <sys/types.h>
49 #include <fontconfig/fontconfig.h>
50 #include <fontconfig/fcprivate.h>
51 #include "fcdeprecate.h"
53 #ifndef FC_CONFIG_PATH
54 #define FC_CONFIG_PATH "fonts.conf"
58 #define FC_SEARCH_PATH_SEPARATOR ';'
60 #define FC_SEARCH_PATH_SEPARATOR ':'
63 #define FC_DBG_MATCH 1
64 #define FC_DBG_MATCHV 2
66 #define FC_DBG_FONTSET 8
67 #define FC_DBG_CACHE 16
68 #define FC_DBG_CACHEV 32
69 #define FC_DBG_PARSE 64
70 #define FC_DBG_SCAN 128
71 #define FC_DBG_SCANV 256
72 #define FC_DBG_MEMORY 512
73 #define FC_DBG_CONFIG 1024
74 #define FC_DBG_LANGSET 2048
75 #define FC_DBG_OBJTYPES 4096
77 #define FC_MEM_CHARSET 0
78 #define FC_MEM_CHARLEAF 1
79 #define FC_MEM_FONTSET 2
80 #define FC_MEM_FONTPTR 3
81 #define FC_MEM_OBJECTSET 4
82 #define FC_MEM_OBJECTPTR 5
83 #define FC_MEM_MATRIX 6
84 #define FC_MEM_PATTERN 7
85 #define FC_MEM_PATELT 8
86 #define FC_MEM_VALLIST 9
87 #define FC_MEM_SUBSTATE 10
88 #define FC_MEM_STRING 11
89 #define FC_MEM_LISTBUCK 12
90 #define FC_MEM_STRSET 13
91 #define FC_MEM_STRLIST 14
92 #define FC_MEM_CONFIG 15
93 #define FC_MEM_LANGSET 16
94 #define FC_MEM_ATOMIC 17
95 #define FC_MEM_BLANKS 18
96 #define FC_MEM_CACHE 19
97 #define FC_MEM_STRBUF 20
98 #define FC_MEM_SUBST 21
99 #define FC_MEM_OBJECTTYPE 22
100 #define FC_MEM_CONSTANT 23
101 #define FC_MEM_TEST 24
102 #define FC_MEM_EXPR 25
103 #define FC_MEM_VSTACK 26
104 #define FC_MEM_ATTR 27
105 #define FC_MEM_PSTACK 28
106 #define FC_MEM_STATICSTR 29
108 #define FC_MEM_NUM 30
110 #define FC_MIN(a,b) ((a) < (b) ? (a) : (b))
111 #define FC_MAX(a,b) ((a) > (b) ? (a) : (b))
112 #define FC_ABS(a) ((a) < 0 ? -(a) : (a))
114 /* slim_internal.h */
115 #if (__GNUC__ > 3 || (__GNUC__ == 3 && __GNUC_MINOR__ >= 3)) && defined(__ELF__) && !defined(__sun)
116 #define FcPrivate __attribute__((__visibility__("hidden")))
117 #define HAVE_GNUC_ATTRIBUTE 1
119 #elif defined(__SUNPRO_C) && (__SUNPRO_C >= 0x550)
120 #define FcPrivate __hidden
121 #else /* not gcc >= 3.3 and not Sun Studio >= 8 */
125 typedef enum _FcValueBinding {
126 FcValueBindingWeak, FcValueBindingStrong, FcValueBindingSame
130 * Serialized data structures use only offsets instead of pointers
131 * A low bit of 1 indicates an offset.
134 /* Is the provided pointer actually an offset? */
135 #define FcIsEncodedOffset(p) ((((intptr_t) (p)) & 1) != 0)
137 /* Encode offset in a pointer of type t */
138 #define FcOffsetEncode(o,t) ((t *) ((o) | 1))
140 /* Decode a pointer into an offset */
141 #define FcOffsetDecode(p) (((intptr_t) (p)) & ~1)
143 /* Compute pointer offset */
144 #define FcPtrToOffset(b,p) ((intptr_t) (p) - (intptr_t) (b))
146 /* Given base address, offset and type, return a pointer */
147 #define FcOffsetToPtr(b,o,t) ((t *) ((intptr_t) (b) + (o)))
149 /* Given base address, encoded offset and type, return a pointer */
150 #define FcEncodedOffsetToPtr(b,p,t) FcOffsetToPtr(b,FcOffsetDecode(p),t)
152 /* Given base address, pointer and type, return an encoded offset */
153 #define FcPtrToEncodedOffset(b,p,t) FcOffsetEncode(FcPtrToOffset(b,p),t)
155 /* Given a structure, offset member and type, return pointer */
156 #define FcOffsetMember(s,m,t) FcOffsetToPtr(s,(s)->m,t)
158 /* Given a structure, encoded offset member and type, return pointer to member */
159 #define FcEncodedOffsetMember(s,m,t) FcOffsetToPtr(s,FcOffsetDecode((s)->m), t)
161 /* Given a structure, member and type, convert the member to a pointer */
162 #define FcPointerMember(s,m,t) (FcIsEncodedOffset((s)->m) ? \
163 FcEncodedOffsetMember (s,m,t) : \
167 * Serialized values may hold strings, charsets and langsets as pointers,
168 * unfortunately FcValue is an exposed type so we can't just always use
171 #define FcValueString(v) FcPointerMember(v,u.s,FcChar8)
172 #define FcValueCharSet(v) FcPointerMember(v,u.c,const FcCharSet)
173 #define FcValueLangSet(v) FcPointerMember(v,u.l,const FcLangSet)
175 typedef struct _FcValueList *FcValueListPtr;
177 typedef struct _FcValueList {
178 struct _FcValueList *next;
180 FcValueBinding binding;
183 #define FcValueListNext(vl) FcPointerMember(vl,next,FcValueList)
185 typedef int FcObject;
187 typedef struct _FcPatternElt *FcPatternEltPtr;
190 * Pattern elts are stuck in a structure connected to the pattern,
191 * so they get moved around when the pattern is resized. Hence, the
192 * values field must be a pointer/offset instead of just an offset
194 typedef struct _FcPatternElt {
199 #define FcPatternEltValues(pe) FcPointerMember(pe,values,FcValueList)
204 intptr_t elts_offset;
208 #define FcPatternElts(p) FcOffsetMember(p,elts_offset,FcPatternElt)
210 #define FcFontSetFonts(fs) FcPointerMember(fs,fonts,FcPattern *)
212 #define FcFontSetFont(fs,i) (FcIsEncodedOffset((fs)->fonts) ? \
213 FcEncodedOffsetToPtr(fs, \
214 FcFontSetFonts(fs)[i], \
219 FcOpInteger, FcOpDouble, FcOpString, FcOpMatrix, FcOpRange, FcOpBool, FcOpCharSet, FcOpLangSet,
221 FcOpField, FcOpConst,
222 FcOpAssign, FcOpAssignReplace,
223 FcOpPrependFirst, FcOpPrepend, FcOpAppend, FcOpAppendLast,
225 FcOpOr, FcOpAnd, FcOpEqual, FcOpNotEqual,
226 FcOpContains, FcOpListing, FcOpNotContains,
227 FcOpLess, FcOpLessEqual, FcOpMore, FcOpMoreEqual,
228 FcOpPlus, FcOpMinus, FcOpTimes, FcOpDivide,
229 FcOpNot, FcOpComma, FcOpFloor, FcOpCeil, FcOpRound, FcOpTrunc,
233 typedef struct _FcExpr {
246 struct _FcExpr *left, *right;
251 typedef struct _FcExprPage FcExprPage;
254 FcExprPage *next_page;
256 FcExpr exprs[(1024 - 2/* two pointers */ - 2/* malloc overhead */) * sizeof (void *) / sizeof (FcExpr)];
260 typedef enum _FcQual {
261 FcQualAny, FcQualAll, FcQualFirst, FcQualNotFirst
264 #define FcMatchDefault ((FcMatchKind) -1)
266 typedef struct _FcTest {
267 struct _FcTest *next;
275 typedef struct _FcEdit {
276 struct _FcEdit *next;
280 FcValueBinding binding;
283 typedef struct _FcSubst {
284 struct _FcSubst *next;
289 typedef struct _FcCharLeaf {
290 FcChar32 map[256/32];
293 #define FC_REF_CONSTANT -1
296 int ref; /* reference count */
297 int num; /* size of leaves and numbers arrays */
298 intptr_t leaves_offset;
299 intptr_t numbers_offset;
302 #define FcCharSetLeaves(c) FcOffsetMember(c,leaves_offset,intptr_t)
303 #define FcCharSetLeaf(c,i) (FcOffsetToPtr(FcCharSetLeaves(c), \
304 FcCharSetLeaves(c)[i], \
306 #define FcCharSetNumbers(c) FcOffsetMember(c,numbers_offset,FcChar16)
309 int ref; /* reference count */
320 typedef struct _FcStrBuf {
326 FcChar8 buf_static[16 * sizeof (void *)];
330 int magic; /* FC_CACHE_MAGIC_MMAP or FC_CACHE_ALLOC */
331 int version; /* FC_CACHE_CONTENT_VERSION */
332 intptr_t size; /* size of file */
333 intptr_t dir; /* offset to dir name */
334 intptr_t dirs; /* offset to subdirs */
335 int dirs_count; /* number of subdir strings */
336 intptr_t set; /* offset to font set */
337 int mtime; /* low bits of directory mtime */
342 #define FcCacheDir(c) FcOffsetMember(c,dir,FcChar8)
343 #define FcCacheDirs(c) FcOffsetMember(c,dirs,intptr_t)
344 #define FcCacheSet(c) FcOffsetMember(c,set,FcFontSet)
345 #define FcCacheSubdir(c,i) FcOffsetToPtr (FcCacheDirs(c),\
350 * Used while constructing a directory cache object
353 #define FC_SERIALIZE_HASH_SIZE 8191
355 typedef union _FcAlign {
363 typedef struct _FcSerializeBucket {
364 struct _FcSerializeBucket *next;
369 typedef struct _FcCharSetFreezer FcCharSetFreezer;
371 typedef struct _FcSerialize {
373 FcCharSetFreezer *cs_freezer;
375 FcSerializeBucket *buckets[FC_SERIALIZE_HASH_SIZE];
379 * To map adobe glyph names to unicode values, a precomputed hash
383 typedef struct _FcGlyphName {
384 FcChar32 ucs; /* unicode value */
385 FcChar8 name[1]; /* name extends beyond struct */
389 * To perform case-insensitive string comparisons, a table
390 * is used which holds three different kinds of folding data.
392 * The first is a range of upper case values mapping to a range
393 * of their lower case equivalents. Within each range, the offset
394 * between upper and lower case is constant.
396 * The second is a range of upper case values which are interleaved
397 * with their lower case equivalents.
399 * The third is a set of raw unicode values mapping to a list
400 * of unicode values for comparison purposes. This allows conversion
401 * of ß to "ss" so that SS, ss and ß all match. A separate array
402 * holds the list of unicode values for each entry.
404 * These are packed into a single table. Using a binary search,
405 * the appropriate entry can be located.
408 #define FC_CASE_FOLD_RANGE 0
409 #define FC_CASE_FOLD_EVEN_ODD 1
410 #define FC_CASE_FOLD_FULL 2
412 typedef struct _FcCaseFold {
416 short offset; /* lower - upper for RANGE, table id for FULL */
419 #define FC_MAX_FILE_LEN 4096
421 #define FC_CACHE_MAGIC_MMAP 0xFC02FC04
422 #define FC_CACHE_MAGIC_ALLOC 0xFC02FC05
423 #define FC_CACHE_CONTENT_VERSION 3 /* also check FC_CACHE_VERSION */
426 FcChar8 *file; /* original file name */
427 FcChar8 *new; /* temp file name -- write data here */
428 FcChar8 *lck; /* lockfile name (used for locking) */
429 FcChar8 *tmp; /* tmpfile name (used for locking) */
440 * File names loaded from the configuration -- saved here as the
441 * cache file must be consulted before the directories are scanned,
442 * and those directives may occur in any order
444 FcStrSet *configDirs; /* directories to scan for fonts */
446 * Set of allowed blank chars -- used to
447 * trim fonts of bogus glyphs
451 * List of directories containing fonts,
452 * built by recursively scanning the set
453 * of configured directories
457 * List of directories containing cache files.
461 * Names of all of the configuration files used
462 * to create this configuration
464 FcStrSet *configFiles; /* config files loaded */
466 * Substitution instructions for patterns and fonts;
467 * maxObjects is used to allocate appropriate intermediate storage
468 * while performing a whole set of substitutions
470 FcSubst *substPattern; /* substitutions for patterns */
471 FcSubst *substFont; /* substitutions for fonts */
472 FcSubst *substScan; /* substitutions for scanned fonts */
473 int maxObjects; /* maximum number of tests in all substs */
475 * List of patterns used to control font file selection
477 FcStrSet *acceptGlobs;
478 FcStrSet *rejectGlobs;
479 FcFontSet *acceptPatterns;
480 FcFontSet *rejectPatterns;
482 * The set of fonts loaded from the listed directories; the
483 * order within the set does not determine the font selection,
484 * except in the case of identical matches in which case earlier fonts
485 * match preferrentially
487 FcFontSet *fonts[FcSetApplication + 1];
489 * Fontconfig can periodically rescan the system configuration
490 * and font directories. This rescanning occurs when font
491 * listing requests are made, but no more often than rescanInterval
494 time_t rescanTime; /* last time information was scanned */
495 int rescanInterval; /* interval between scans */
497 int ref; /* reference count */
499 FcExprPage *expr_pool; /* pool of FcExpr's */
502 extern FcPrivate FcConfig *_fcConfig;
504 typedef struct _FcFileTime {
509 typedef struct _FcCharMap FcCharMap;
511 typedef struct _FcRange FcRange;
523 FcDirCacheScan (const FcChar8 *dir, FcConfig *config);
526 FcDirCacheBuild (FcFontSet *set, const FcChar8 *dir, struct stat *dir_stat, FcStrSet *dirs);
529 FcDirCacheWrite (FcCache *cache, FcConfig *config);
532 FcCacheObjectReference (void *object);
535 FcCacheObjectDereference (void *object);
541 FcDirCacheReference (FcCache *cache, int nref);
545 FcStat (const char *file, struct stat *statb);
553 FcConfigAllocExpr (FcConfig *config);
556 FcConfigAddConfigDir (FcConfig *config,
560 FcConfigAddFontDir (FcConfig *config,
564 FcConfigAddDir (FcConfig *config,
568 FcConfigAddCacheDir (FcConfig *config,
572 FcConfigAddConfigFile (FcConfig *config,
576 FcConfigAddBlank (FcConfig *config,
580 FcConfigAddEdit (FcConfig *config,
586 FcConfigSetFonts (FcConfig *config,
591 FcConfigCompareValue (const FcValue *m,
596 FcConfigGlobAdd (FcConfig *config,
601 FcConfigAcceptFilename (FcConfig *config,
602 const FcChar8 *filename);
605 FcConfigPatternsAdd (FcConfig *config,
610 FcConfigAcceptFont (FcConfig *config,
611 const FcPattern *font);
614 FcConfigModifiedTime (FcConfig *config);
617 FcConfigAddCache (FcConfig *config, FcCache *cache,
618 FcSetName set, FcStrSet *dirSet);
622 FcAlignSize (intptr_t size);
624 FcPrivate FcSerialize *
625 FcSerializeCreate (void);
628 FcSerializeDestroy (FcSerialize *serialize);
631 FcSerializeAlloc (FcSerialize *serialize, const void *object, int size);
634 FcSerializeReserve (FcSerialize *serialize, int size);
637 FcSerializeOffset (FcSerialize *serialize, const void *object);
640 FcSerializePtr (FcSerialize *serialize, const void *object);
643 FcLangSetSerializeAlloc (FcSerialize *serialize, const FcLangSet *l);
645 FcPrivate FcLangSet *
646 FcLangSetSerialize(FcSerialize *serialize, const FcLangSet *l);
650 FcLangCharSetPopulate (void);
652 FcPrivate FcCharSetFreezer *
653 FcCharSetFreezerCreate (void);
655 FcPrivate const FcCharSet *
656 FcCharSetFreeze (FcCharSetFreezer *freezer, const FcCharSet *fcs);
659 FcCharSetFreezerDestroy (FcCharSetFreezer *freezer);
662 FcNameUnparseCharSet (FcStrBuf *buf, const FcCharSet *c);
664 FcPrivate FcCharSet *
665 FcNameParseCharSet (FcChar8 *string);
668 FcNameUnparseValue (FcStrBuf *buf,
673 FcNameUnparseValueList (FcStrBuf *buf,
677 FcPrivate FcCharLeaf *
678 FcCharSetFindLeafCreate (FcCharSet *fcs, FcChar32 ucs4);
681 FcCharSetSerializeAlloc(FcSerialize *serialize, const FcCharSet *cs);
683 FcPrivate FcCharSet *
684 FcCharSetSerialize(FcSerialize *serialize, const FcCharSet *cs);
687 FcCharSetGetNumbers(const FcCharSet *c);
691 FcValueListPrint (const FcValueListPtr l);
694 FcLangSetPrint (const FcLangSet *ls);
700 FcTestPrint (const FcTest *test);
703 FcExprPrint (const FcExpr *expr);
706 FcEditPrint (const FcEdit *edit);
709 FcSubstPrint (const FcSubst *subst);
712 FcCharSetPrint (const FcCharSet *c);
714 extern FcPrivate int FcDebugVal;
716 #define FcDebug() (FcDebugVal)
723 FcGetDefaultLang (void);
728 FcFileScanConfig (FcFontSet *set,
735 FcDirScanConfig (FcFontSet *set,
749 FcFontSetSerializeAlloc (FcSerialize *serialize, const FcFontSet *s);
751 FcPrivate FcFontSet *
752 FcFontSetSerialize (FcSerialize *serialize, const FcFontSet * s);
756 FcTestDestroy (FcTest *test);
759 FcEditDestroy (FcEdit *e);
767 FcMemAlloc (int kind, int size);
770 FcMemFree (int kind, int size);
773 FcPrivate FcLangSet *
774 FcFreeTypeLangSet (const FcCharSet *charset,
775 const FcChar8 *exclusiveLang);
777 FcPrivate FcLangResult
778 FcLangCompare (const FcChar8 *s1, const FcChar8 *s2);
780 FcPrivate FcLangSet *
781 FcLangSetPromote (const FcChar8 *lang);
783 FcPrivate FcLangSet *
784 FcNameParseLangSet (const FcChar8 *string);
787 FcNameUnparseLangSet (FcStrBuf *buf, const FcLangSet *ls);
790 FcNameUnparseEscaped (FcPattern *pat, FcBool escape);
795 FcListPatternMatchAny (const FcPattern *p,
796 const FcPattern *font);
803 * NOTE -- this ordering is part of the cache file format.
804 * It must also match the ordering in fcname.c
807 #define FC_FAMILY_OBJECT 1
808 #define FC_FAMILYLANG_OBJECT 2
809 #define FC_STYLE_OBJECT 3
810 #define FC_STYLELANG_OBJECT 4
811 #define FC_FULLNAME_OBJECT 5
812 #define FC_FULLNAMELANG_OBJECT 6
813 #define FC_SLANT_OBJECT 7
814 #define FC_WEIGHT_OBJECT 8
815 #define FC_WIDTH_OBJECT 9
816 #define FC_SIZE_OBJECT 10
817 #define FC_ASPECT_OBJECT 11
818 #define FC_PIXEL_SIZE_OBJECT 12
819 #define FC_SPACING_OBJECT 13
820 #define FC_FOUNDRY_OBJECT 14
821 #define FC_ANTIALIAS_OBJECT 15
822 #define FC_HINT_STYLE_OBJECT 16
823 #define FC_HINTING_OBJECT 17
824 #define FC_VERTICAL_LAYOUT_OBJECT 18
825 #define FC_AUTOHINT_OBJECT 19
826 #define FC_GLOBAL_ADVANCE_OBJECT 20
827 #define FC_FILE_OBJECT 21
828 #define FC_INDEX_OBJECT 22
829 #define FC_RASTERIZER_OBJECT 23
830 #define FC_OUTLINE_OBJECT 24
831 #define FC_SCALABLE_OBJECT 25
832 #define FC_DPI_OBJECT 26
833 #define FC_RGBA_OBJECT 27
834 #define FC_SCALE_OBJECT 28
835 #define FC_MINSPACE_OBJECT 29
836 #define FC_CHAR_WIDTH_OBJECT 30
837 #define FC_CHAR_HEIGHT_OBJECT 31
838 #define FC_MATRIX_OBJECT 32
839 #define FC_CHARSET_OBJECT 33
840 #define FC_LANG_OBJECT 34
841 #define FC_FONTVERSION_OBJECT 35
842 #define FC_CAPABILITY_OBJECT 36
843 #define FC_FONTFORMAT_OBJECT 37
844 #define FC_EMBOLDEN_OBJECT 38
845 #define FC_EMBEDDED_BITMAP_OBJECT 39
846 #define FC_DECORATIVE_OBJECT 40
847 #define FC_LCD_FILTER_OBJECT 41
848 #define FC_MAX_BASE_OBJECT FC_LCD_FILTER_OBJECT
851 FcNameBool (const FcChar8 *v, FcBool *result);
854 FcObjectValidType (FcObject object, FcType type);
857 FcObjectFromName (const char * name);
859 FcPrivate const char *
860 FcObjectName (FcObject object);
862 FcPrivate FcObjectSet *
863 FcObjectGetSet (void);
871 #define FcObjectCompare(a, b) ((int) a - (int) b)
876 FcValueCanonicalize (const FcValue *v);
879 FcValueListDestroy (FcValueListPtr l);
881 FcPrivate FcPatternElt *
882 FcPatternObjectFindElt (const FcPattern *p, FcObject object);
884 FcPrivate FcPatternElt *
885 FcPatternObjectInsertElt (FcPattern *p, FcObject object);
888 FcPatternObjectAddWithBinding (FcPattern *p,
891 FcValueBinding binding,
895 FcPatternObjectAdd (FcPattern *p, FcObject object, FcValue value, FcBool append);
898 FcPatternObjectAddWeak (FcPattern *p, FcObject object, FcValue value, FcBool append);
901 FcPatternObjectGet (const FcPattern *p, FcObject object, int id, FcValue *v);
904 FcPatternObjectDel (FcPattern *p, FcObject object);
907 FcPatternObjectRemove (FcPattern *p, FcObject object, int id);
910 FcPatternObjectAddInteger (FcPattern *p, FcObject object, int i);
913 FcPatternObjectAddDouble (FcPattern *p, FcObject object, double d);
916 FcPatternObjectAddString (FcPattern *p, FcObject object, const FcChar8 *s);
919 FcPatternObjectAddMatrix (FcPattern *p, FcObject object, const FcMatrix *s);
922 FcPatternObjectAddCharSet (FcPattern *p, FcObject object, const FcCharSet *c);
925 FcPatternObjectAddBool (FcPattern *p, FcObject object, FcBool b);
928 FcPatternObjectAddLangSet (FcPattern *p, FcObject object, const FcLangSet *ls);
931 FcPatternObjectGetInteger (const FcPattern *p, FcObject object, int n, int *i);
934 FcPatternObjectGetDouble (const FcPattern *p, FcObject object, int n, double *d);
937 FcPatternObjectGetString (const FcPattern *p, FcObject object, int n, FcChar8 ** s);
940 FcPatternObjectGetMatrix (const FcPattern *p, FcObject object, int n, FcMatrix **s);
943 FcPatternObjectGetCharSet (const FcPattern *p, FcObject object, int n, FcCharSet **c);
946 FcPatternObjectGetBool (const FcPattern *p, FcObject object, int n, FcBool *b);
949 FcPatternObjectGetLangSet (const FcPattern *p, FcObject object, int n, FcLangSet **ls);
952 FcPatternFini (void);
955 FcPatternAppend (FcPattern *p, FcPattern *s);
957 FcPrivate const FcChar8 *
958 FcStrStaticName (const FcChar8 *name);
961 FcStringHash (const FcChar8 *s);
964 FcPatternSerializeAlloc (FcSerialize *serialize, const FcPattern *pat);
966 FcPrivate FcPattern *
967 FcPatternSerialize (FcSerialize *serialize, const FcPattern *pat);
970 FcValueListSerializeAlloc (FcSerialize *serialize, const FcValueList *pat);
972 FcPrivate FcValueList *
973 FcValueListSerialize (FcSerialize *serialize, const FcValueList *pat);
979 extern FcPrivate const FcMatrix FcIdentityMatrix;
982 FcMatrixFree (FcMatrix *mat);
986 FcStrSetSort (FcStrSet * set);
989 FcStrBufInit (FcStrBuf *buf, FcChar8 *init, int size);
992 FcStrBufDestroy (FcStrBuf *buf);
995 FcStrBufDone (FcStrBuf *buf);
998 FcStrBufDoneStatic (FcStrBuf *buf);
1001 FcStrBufChar (FcStrBuf *buf, FcChar8 c);
1004 FcStrBufString (FcStrBuf *buf, const FcChar8 *s);
1007 FcStrBufData (FcStrBuf *buf, const FcChar8 *s, int len);
1010 FcStrCmpIgnoreBlanksAndCase (const FcChar8 *s1, const FcChar8 *s2);
1012 FcPrivate const FcChar8 *
1013 FcStrContainsIgnoreBlanksAndCase (const FcChar8 *s1, const FcChar8 *s2);
1015 FcPrivate const FcChar8 *
1016 FcStrContainsIgnoreCase (const FcChar8 *s1, const FcChar8 *s2);
1018 FcPrivate const FcChar8 *
1019 FcStrContainsWord (const FcChar8 *s1, const FcChar8 *s2);
1022 FcStrUsesHome (const FcChar8 *s);
1025 FcStrLastSlash (const FcChar8 *path);
1028 FcStrHashIgnoreCase (const FcChar8 *s);
1031 FcStrCanonFilename (const FcChar8 *s);
1034 FcStrSerializeAlloc (FcSerialize *serialize, const FcChar8 *str);
1037 FcStrSerialize (FcSerialize *serialize, const FcChar8 *str);
1039 #endif /* _FC_INT_H_ */