]> git.wh0rd.org Git - fontconfig.git/blob - src/fcint.h
Skip broken caches. Cache files are auto-written, don't rewrite in fc-cache.
[fontconfig.git] / src / fcint.h
1 /*
2  * $RCSId: xc/lib/fontconfig/src/fcint.h,v 1.27 2002/08/31 22:17:32 keithp Exp $
3  *
4  * Copyright © 2000 Keith Packard
5  *
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 Keith Packard not be used in
11  * advertising or publicity pertaining to distribution of the software without
12  * specific, written prior permission.  Keith Packard makes no
13  * representations about the suitability of this software for any purpose.  It
14  * is provided "as is" without express or implied warranty.
15  *
16  * KEITH PACKARD DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
17  * INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO
18  * EVENT SHALL KEITH PACKARD 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.
23  */
24
25 #ifndef _FCINT_H_
26 #define _FCINT_H_
27
28 #ifdef HAVE_CONFIG_H
29 #include <config.h>
30 #endif
31
32 #include <stdlib.h>
33 #include <stdio.h>
34 #ifdef HAVE_INTTYPES_H
35 #include <inttypes.h>
36 #elif defined(HAVE_STDINT_H)
37 #include <stdint.h>
38 #else
39 #error missing C99 integer data types
40 #endif
41 #include <string.h>
42 #include <ctype.h>
43 #include <errno.h>
44 #include <unistd.h>
45 #include <sys/types.h>
46 #include <sys/stat.h>
47 #include <time.h>
48 #include <fontconfig/fontconfig.h>
49 #include <fontconfig/fcprivate.h>
50 #include <fontconfig/fcfreetype.h>
51
52 #ifndef FC_CONFIG_PATH
53 #define FC_CONFIG_PATH "fonts.conf"
54 #endif
55
56 #define FC_FONT_FILE_INVALID    ((FcChar8 *) ".")
57 #define FC_FONT_FILE_DIR        ((FcChar8 *) ".dir")
58 #define FC_GLOBAL_MAGIC_COOKIE  "GLOBAL"
59
60 #ifdef _WIN32
61 #define FC_SEARCH_PATH_SEPARATOR ';'
62 #else
63 #define FC_SEARCH_PATH_SEPARATOR ':'
64 #endif
65
66 #define FC_DBG_MATCH    1
67 #define FC_DBG_MATCHV   2
68 #define FC_DBG_EDIT     4
69 #define FC_DBG_FONTSET  8
70 #define FC_DBG_CACHE    16
71 #define FC_DBG_CACHEV   32
72 #define FC_DBG_PARSE    64
73 #define FC_DBG_SCAN     128
74 #define FC_DBG_SCANV    256
75 #define FC_DBG_MEMORY   512
76 #define FC_DBG_CONFIG   1024
77 #define FC_DBG_LANGSET  2048
78
79 #define FC_MEM_CHARSET      0
80 #define FC_MEM_CHARLEAF     1
81 #define FC_MEM_FONTSET      2
82 #define FC_MEM_FONTPTR      3
83 #define FC_MEM_OBJECTSET    4
84 #define FC_MEM_OBJECTPTR    5
85 #define FC_MEM_MATRIX       6
86 #define FC_MEM_PATTERN      7
87 #define FC_MEM_PATELT       8
88 #define FC_MEM_VALLIST      9
89 #define FC_MEM_SUBSTATE     10
90 #define FC_MEM_STRING       11
91 #define FC_MEM_LISTBUCK     12
92 #define FC_MEM_STRSET       13
93 #define FC_MEM_STRLIST      14
94 #define FC_MEM_CONFIG       15
95 #define FC_MEM_LANGSET      16
96 #define FC_MEM_ATOMIC       17
97 #define FC_MEM_BLANKS       18
98 #define FC_MEM_CACHE        19
99 #define FC_MEM_STRBUF       20
100 #define FC_MEM_SUBST        21
101 #define FC_MEM_OBJECTTYPE   22
102 #define FC_MEM_CONSTANT     23
103 #define FC_MEM_TEST         24
104 #define FC_MEM_EXPR         25
105 #define FC_MEM_VSTACK       26
106 #define FC_MEM_ATTR         27
107 #define FC_MEM_PSTACK       28
108 #define FC_MEM_STATICSTR    29
109
110 #define FC_MEM_NUM          30
111
112 #define FC_BANK_DYNAMIC 0
113 #define FC_BANK_FIRST 1
114 #define FC_BANK_LANGS       0xfcfcfcfc
115
116 typedef enum _FcValueBinding {
117     FcValueBindingWeak, FcValueBindingStrong, FcValueBindingSame
118 } FcValueBinding;
119
120 /*
121  * Serialized data structures use only offsets instead of pointers
122  * A low bit of 1 indicates an offset.
123  */
124  
125 /* Is the provided pointer actually an offset? */
126 #define FcIsEncodedOffset(p)    ((((intptr_t) (p)) & 1) != 0)
127
128 /* Encode offset in a pointer of type t */
129 #define FcOffsetEncode(o,t)     ((t *) ((o) | 1))
130
131 /* Decode a pointer into an offset */
132 #define FcOffsetDecode(p)       (((intptr_t) (p)) & ~1)
133
134 /* Compute pointer offset */
135 #define FcPtrToOffset(b,p)      ((intptr_t) (p) - (intptr_t) (b))
136
137 /* Given base address, offset and type, return a pointer */
138 #define FcOffsetToPtr(b,o,t)    ((t *) ((intptr_t) (b) + (o)))
139
140 /* Given base address, encoded offset and type, return a pointer */
141 #define FcEncodedOffsetToPtr(b,p,t) FcOffsetToPtr(b,FcOffsetDecode(p),t)
142
143 /* Given base address, pointer and type, return an encoded offset */
144 #define FcPtrToEncodedOffset(b,p,t) FcOffsetEncode(FcPtrToOffset(b,p),t)
145
146 /* Given a structure, offset member and type, return pointer */
147 #define FcOffsetMember(s,m,t)       FcOffsetToPtr(s,(s)->m,t)
148
149 /* Given a structure, encoded offset member and type, return pointer to member */
150 #define FcEncodedOffsetMember(s,m,t) FcOffsetToPtr(s,FcOffsetDecode((s)->m), t)
151
152 /* Given a structure, member and type, convert the member to a pointer */
153 #define FcPointerMember(s,m,t)  (FcIsEncodedOffset((s)->m) ? \
154                                  FcEncodedOffsetMember (s,m,t) : \
155                                  (s)->m)
156
157 /*
158  * Serialized values may hold strings, charsets and langsets as pointers,
159  * unfortunately FcValue is an exposed type so we can't just always use
160  * offsets
161  */
162 #define FcValueString(v)        FcPointerMember(v,u.s,FcChar8)
163 #define FcValueCharSet(v)       FcPointerMember(v,u.c,const FcCharSet)
164 #define FcValueLangSet(v)       FcPointerMember(v,u.l,const FcLangSet)
165
166 typedef struct _FcValueList *FcValueListPtr;
167
168 typedef struct _FcValueList {
169     struct _FcValueList *next;
170     FcValue             value;
171     FcValueBinding      binding;
172 } FcValueList;
173
174 #define FcValueListNext(vl)     FcPointerMember(vl,next,FcValueList)
175                              
176 typedef int FcObject;
177
178 typedef struct _FcPatternElt *FcPatternEltPtr;
179
180 /*
181  * Pattern elts are stuck in a structure connected to the pattern, 
182  * so they get moved around when the pattern is resized. Hence, the
183  * values field must be a pointer/offset instead of just an offset
184  */
185 typedef struct _FcPatternElt {
186     FcObject            object;
187     FcValueList         *values;
188 } FcPatternElt;
189
190 #define FcPatternEltValues(pe)  FcPointerMember(pe,values,FcValueList)
191
192 struct _FcPattern {
193     int             num;
194     int             size;
195     intptr_t        elts_offset;
196     int             ref;
197 };
198
199 #define FcPatternElts(p)        FcOffsetMember(p,elts_offset,FcPatternElt)
200
201 #define FcFontSetFonts(fs)      FcPointerMember(fs,fonts,FcPattern *)
202
203 #define FcFontSetFont(fs,i)     (FcIsEncodedOffset((fs)->fonts) ? \
204                                  FcEncodedOffsetToPtr(FcFontSetFonts(fs), \
205                                                       FcFontSetFonts(fs)[i], \
206                                                       FcPattern) : \
207                                  fs->fonts[i])
208                                                 
209 typedef enum _FcOp {
210     FcOpInteger, FcOpDouble, FcOpString, FcOpMatrix, FcOpBool, FcOpCharSet, 
211     FcOpNil,
212     FcOpField, FcOpConst,
213     FcOpAssign, FcOpAssignReplace, 
214     FcOpPrependFirst, FcOpPrepend, FcOpAppend, FcOpAppendLast,
215     FcOpQuest,
216     FcOpOr, FcOpAnd, FcOpEqual, FcOpNotEqual, 
217     FcOpContains, FcOpListing, FcOpNotContains,
218     FcOpLess, FcOpLessEqual, FcOpMore, FcOpMoreEqual,
219     FcOpPlus, FcOpMinus, FcOpTimes, FcOpDivide,
220     FcOpNot, FcOpComma, FcOpFloor, FcOpCeil, FcOpRound, FcOpTrunc,
221     FcOpInvalid
222 } FcOp;
223
224 typedef struct _FcExpr {
225     FcOp   op;
226     union {
227         int         ival;
228         double      dval;
229         FcChar8     *sval;
230         FcMatrix    *mval;
231         FcBool      bval;
232         FcCharSet   *cval;
233         FcObject    object;
234         FcChar8     *constant;
235         struct {
236             struct _FcExpr *left, *right;
237         } tree;
238     } u;
239 } FcExpr;
240
241 typedef enum _FcQual {
242     FcQualAny, FcQualAll, FcQualFirst, FcQualNotFirst
243 } FcQual;
244
245 #define FcMatchDefault  ((FcMatchKind) -1)
246
247 typedef struct _FcTest {
248     struct _FcTest      *next;
249     FcMatchKind         kind;
250     FcQual              qual;
251     FcObject            object;
252     FcOp                op;
253     FcExpr              *expr;
254 } FcTest;
255
256 typedef struct _FcEdit {
257     struct _FcEdit *next;
258     FcObject        object;
259     FcOp            op;
260     FcExpr          *expr;
261     FcValueBinding  binding;
262 } FcEdit;
263
264 typedef struct _FcSubst {
265     struct _FcSubst     *next;
266     FcTest              *test;
267     FcEdit              *edit;
268 } FcSubst;
269
270 typedef struct _FcCharLeaf {
271     FcChar32    map[256/32];
272 } FcCharLeaf;
273
274 #define FC_REF_CONSTANT     -1
275
276 struct _FcCharSet {
277     int             ref;        /* reference count */
278     int             num;        /* size of leaves and numbers arrays */
279     intptr_t        leaves_offset;
280     intptr_t        numbers_offset;
281 };
282
283 #define FcCharSetLeaves(c)      FcOffsetMember(c,leaves_offset,intptr_t)
284 #define FcCharSetLeaf(c,i)      (FcOffsetToPtr(FcCharSetLeaves(c), \
285                                                FcCharSetLeaves(c)[i], \
286                                                FcCharLeaf))
287 #define FcCharSetNumbers(c)     FcOffsetMember(c,numbers_offset,FcChar16)
288
289 struct _FcStrSet {
290     int             ref;        /* reference count */
291     int             num;
292     int             size;
293     FcChar8         **strs;
294 };
295
296 struct _FcStrList {
297     FcStrSet        *set;
298     int             n;
299 };
300
301 typedef struct _FcStrBuf {
302     FcChar8 *buf;
303     FcBool  allocated;
304     FcBool  failed;
305     int     len;
306     int     size;
307 } FcStrBuf;
308
309 typedef struct _FcCache {
310     int         magic;              /* FC_CACHE_MAGIC */
311     off_t       size;               /* size of file */
312     intptr_t    dir;                /* offset to dir name */
313     intptr_t    dirs;               /* offset to subdirs */
314     int         dirs_count;         /* number of subdir strings */
315     intptr_t    set;                /* offset to font set */
316 } FcCache;
317
318 #define FcCacheDir(c)   FcOffsetMember(c,dir,FcChar8)
319 #define FcCacheDirs(c)  FcOffsetMember(c,dirs,intptr_t)
320 #define FcCacheSet(c)   FcOffsetMember(c,set,FcFontSet)
321
322 /*
323  * Used while constructing a directory cache object
324  */
325
326 #define FC_SERIALIZE_HASH_SIZE  8191
327
328 typedef struct _FcSerializeBucket {
329     struct _FcSerializeBucket *next;
330     const void  *object;
331     intptr_t    offset;
332 } FcSerializeBucket;
333
334 typedef struct _FcSerialize {
335     intptr_t            size;
336     void                *linear;
337     FcSerializeBucket   *buckets[FC_SERIALIZE_HASH_SIZE];
338 } FcSerialize;
339     
340 /*
341  * To map adobe glyph names to unicode values, a precomputed hash
342  * table is used
343  */
344
345 typedef struct _FcGlyphName {
346     FcChar32    ucs;            /* unicode value */
347     FcChar8     name[1];        /* name extends beyond struct */
348 } FcGlyphName;
349
350 /*
351  * To perform case-insensitive string comparisons, a table
352  * is used which holds three different kinds of folding data.
353  * 
354  * The first is a range of upper case values mapping to a range
355  * of their lower case equivalents.  Within each range, the offset
356  * between upper and lower case is constant.
357  *
358  * The second is a range of upper case values which are interleaved
359  * with their lower case equivalents.
360  * 
361  * The third is a set of raw unicode values mapping to a list
362  * of unicode values for comparison purposes.  This allows conversion
363  * of ß to "ss" so that SS, ss and ß all match.  A separate array
364  * holds the list of unicode values for each entry.
365  *
366  * These are packed into a single table.  Using a binary search,
367  * the appropriate entry can be located.
368  */
369
370 #define FC_CASE_FOLD_RANGE          0
371 #define FC_CASE_FOLD_EVEN_ODD       1
372 #define FC_CASE_FOLD_FULL           2
373
374 typedef struct _FcCaseFold {
375     FcChar32    upper;
376     FcChar16    method : 2;
377     FcChar16    count : 14;
378     short       offset;     /* lower - upper for RANGE, table id for FULL */
379 } FcCaseFold;
380
381 #define FC_MAX_FILE_LEN     4096
382
383 /* XXX remove these when we're ready */
384
385 #define fc_value_string(v)      FcValueString(v)
386 #define fc_value_charset(v)     FcValueCharSet(v)
387 #define fc_value_langset(v)     FcValueLangSet(v)
388 #define fc_storage_type(v)      ((v)->type)
389
390 #define fc_alignof(type) offsetof (struct { char c; type member; }, member)
391
392 #define FC_CACHE_MAGIC      0xFC02FC04
393 #define FC_CACHE_MAGIC_COPY 0xFC02FC05
394
395 struct _FcAtomic {
396     FcChar8     *file;          /* original file name */
397     FcChar8     *new;           /* temp file name -- write data here */
398     FcChar8     *lck;           /* lockfile name (used for locking) */
399     FcChar8     *tmp;           /* tmpfile name (used for locking) */
400 };
401
402 struct _FcBlanks {
403     int         nblank;
404     int         sblank;
405     FcChar32    *blanks;
406 };
407
408 typedef struct _FcCacheList {
409     struct _FcCacheList *next;
410     FcCache             *cache;
411 } FcCacheList;
412
413 struct _FcConfig {
414     /*
415      * File names loaded from the configuration -- saved here as the
416      * cache file must be consulted before the directories are scanned,
417      * and those directives may occur in any order
418      */
419     FcStrSet    *configDirs;        /* directories to scan for fonts */
420     /*
421      * Set of allowed blank chars -- used to
422      * trim fonts of bogus glyphs
423      */
424     FcBlanks    *blanks;
425     /*
426      * List of directories containing fonts,
427      * built by recursively scanning the set 
428      * of configured directories
429      */
430     FcStrSet    *fontDirs;
431     /*
432      * List of directories containing cache files.
433      */
434     FcStrSet    *cacheDirs;
435     /*
436      * Names of all of the configuration files used
437      * to create this configuration
438      */
439     FcStrSet    *configFiles;       /* config files loaded */
440     /*
441      * Substitution instructions for patterns and fonts;
442      * maxObjects is used to allocate appropriate intermediate storage
443      * while performing a whole set of substitutions
444      */
445     FcSubst     *substPattern;      /* substitutions for patterns */
446     FcSubst     *substFont;         /* substitutions for fonts */
447     int         maxObjects;         /* maximum number of tests in all substs */
448     /*
449      * List of patterns used to control font file selection
450      */
451     FcStrSet    *acceptGlobs;
452     FcStrSet    *rejectGlobs;
453     FcFontSet   *acceptPatterns;
454     FcFontSet   *rejectPatterns;
455     /*
456      * The set of fonts loaded from the listed directories; the
457      * order within the set does not determine the font selection,
458      * except in the case of identical matches in which case earlier fonts
459      * match preferrentially
460      */
461     FcFontSet   *fonts[FcSetApplication + 1];
462     /*
463      * Font cache information is mapped from cache files
464      * the configuration is destroyed, the files need to be unmapped
465      */
466     FcCacheList *caches;
467     /*
468      * Fontconfig can periodically rescan the system configuration
469      * and font directories.  This rescanning occurs when font
470      * listing requests are made, but no more often than rescanInterval
471      * seconds apart.
472      */
473     time_t      rescanTime;         /* last time information was scanned */
474     int         rescanInterval;     /* interval between scans */
475 };
476  
477 extern FcConfig *_fcConfig;
478
479 typedef struct _FcFileTime {
480     time_t  time;
481     FcBool  set;
482 } FcFileTime;
483
484 typedef struct _FcCharMap FcCharMap;
485
486 /* watch out; assumes that v is void * -PL */
487 #define ALIGN(v,type) ((void *)(((uintptr_t)(v) + fc_alignof(type) - 1) & ~(fc_alignof(type) - 1)))
488
489 /* fcblanks.c */
490
491 /* fccache.c */
492
493 FcFontSet *
494 FcCacheRead (FcConfig *config);
495
496 FcBool
497 FcDirCacheWrite (FcFontSet *set, FcStrSet * dirs, const FcChar8 *dir, FcConfig *config);
498
499 FcBool
500 FcDirCacheConsume (FILE *file, FcFontSet *set, FcStrSet *dirs,
501                    const FcChar8 *dir, char *dirname);
502     
503 FcCache *
504 FcDirCacheMap (int fd, off_t size);
505
506 void
507 FcDirCacheUnmap (FcCache *cache);
508
509 FcBool
510 FcDirCacheRead (FcFontSet * set, FcStrSet * dirs, const FcChar8 *dir, FcConfig *config);
511  
512 /* fccfg.c */
513
514 FcBool
515 FcConfigAddConfigDir (FcConfig      *config,
516                       const FcChar8 *d);
517
518 FcBool
519 FcConfigAddFontDir (FcConfig        *config,
520                     const FcChar8   *d);
521
522 FcBool
523 FcConfigAddDir (FcConfig        *config,
524                 const FcChar8   *d);
525
526 FcBool
527 FcConfigAddCacheDir (FcConfig       *config,
528                      const FcChar8  *d);
529
530 FcStrList *
531 FcConfigGetCacheDirs (FcConfig  *config);
532
533 FcBool
534 FcConfigAddConfigFile (FcConfig         *config,
535                        const FcChar8    *f);
536
537 FcBool
538 FcConfigAddBlank (FcConfig      *config,
539                   FcChar32      blank);
540
541 FcBool
542 FcConfigAddEdit (FcConfig       *config,
543                  FcTest         *test,
544                  FcEdit         *edit,
545                  FcMatchKind    kind);
546
547 void
548 FcConfigSetFonts (FcConfig      *config,
549                   FcFontSet     *fonts,
550                   FcSetName     set);
551
552 FcBool
553 FcConfigCompareValue (const FcValue *m,
554                       FcOp          op,
555                       const FcValue *v);
556
557 FcBool
558 FcConfigGlobAdd (FcConfig       *config,
559                  const FcChar8  *glob,
560                  FcBool         accept);
561
562 FcBool
563 FcConfigAcceptFilename (FcConfig        *config,
564                         const FcChar8   *filename);
565
566 FcBool
567 FcConfigPatternsAdd (FcConfig   *config,
568                      FcPattern  *pattern,
569                      FcBool     accept);
570
571 FcBool
572 FcConfigAcceptFont (FcConfig        *config,
573                     const FcPattern *font);
574
575 FcFileTime
576 FcConfigModifiedTime (FcConfig *config);
577
578 FcBool
579 FcConfigAddCache (FcConfig *config, FcCache *cache);
580
581 /* fcserialize.c */
582 intptr_t
583 FcAlignSize (intptr_t size);
584     
585 FcSerialize *
586 FcSerializeCreate (void);
587
588 void
589 FcSerializeDestroy (FcSerialize *serialize);
590
591 FcBool
592 FcSerializeAlloc (FcSerialize *serialize, const void *object, int size);
593
594 intptr_t
595 FcSerializeReserve (FcSerialize *serialize, int size);
596
597 intptr_t
598 FcSerializeOffset (FcSerialize *serialize, const void *object);
599
600 void *
601 FcSerializePtr (FcSerialize *serialize, const void *object);
602
603 FcBool
604 FcLangSetSerializeAlloc (FcSerialize *serialize, const FcLangSet *l);
605
606 FcLangSet *
607 FcLangSetSerialize(FcSerialize *serialize, const FcLangSet *l);
608
609 /* fccharset.c */
610 void
611 FcLangCharSetPopulate (void);
612
613 FcCharSet *
614 FcCharSetFreeze (FcCharSet *cs);
615
616 void
617 FcCharSetThawAll (void);
618
619 FcBool
620 FcNameUnparseCharSet (FcStrBuf *buf, const FcCharSet *c);
621
622 FcCharSet *
623 FcNameParseCharSet (FcChar8 *string);
624
625 FcCharLeaf *
626 FcCharSetFindLeafCreate (FcCharSet *fcs, FcChar32 ucs4);
627
628 FcBool
629 FcCharSetSerializeAlloc(FcSerialize *serialize, const FcCharSet *cs);
630
631 FcCharSet *
632 FcCharSetSerialize(FcSerialize *serialize, const FcCharSet *cs);
633
634 FcChar16 *
635 FcCharSetGetNumbers(const FcCharSet *c);
636
637 /* fcdbg.c */
638 void
639 FcValueListPrint (const FcValueListPtr l);
640
641 void
642 FcLangSetPrint (const FcLangSet *ls);
643
644 void
645 FcOpPrint (FcOp op);
646
647 void
648 FcTestPrint (const FcTest *test);
649
650 void
651 FcExprPrint (const FcExpr *expr);
652
653 void
654 FcEditPrint (const FcEdit *edit);
655
656 void
657 FcSubstPrint (const FcSubst *subst);
658
659 void
660 FcCharSetPrint (const FcCharSet *c);
661     
662 extern int FcDebugVal;
663
664 static inline int
665 FcDebug (void) { return FcDebugVal; }
666
667 void
668 FcInitDebug (void);
669
670 /* fcdefault.c */
671 FcChar8 *
672 FcGetDefaultLang (void);
673
674 /* fcdir.c */
675
676 FcBool
677 FcFileIsDir (const FcChar8 *file);
678
679 FcBool
680 FcFileScanConfig (FcFontSet     *set,
681                   FcStrSet      *dirs,
682                   FcBlanks      *blanks,
683                   const FcChar8 *file,
684                   FcBool        force,
685                   FcConfig      *config);
686
687 FcBool
688 FcDirScanConfig (FcFontSet      *set,
689                  FcStrSet       *dirs,
690                  FcBlanks       *blanks,
691                  const FcChar8  *dir,
692                  FcBool         force,
693                  FcConfig       *config);
694
695 /* fcfont.c */
696 int
697 FcFontDebug (void);
698     
699 /* fcfreetype.c */
700 FcBool
701 FcFreeTypeIsExclusiveLang (const FcChar8  *lang);
702
703 FcBool
704 FcFreeTypeHasLang (FcPattern *pattern, const FcChar8 *lang);
705
706 FcChar32
707 FcFreeTypeUcs4ToPrivate (FcChar32 ucs4, const FcCharMap *map);
708
709 FcChar32
710 FcFreeTypePrivateToUcs4 (FcChar32 private, const FcCharMap *map);
711
712 const FcCharMap *
713 FcFreeTypeGetPrivateMap (FT_Encoding encoding);
714     
715 /* fcfs.c */
716
717 FcBool
718 FcFontSetSerializeAlloc (FcSerialize *serialize, const FcFontSet *s);
719
720 FcFontSet *
721 FcFontSetSerialize (FcSerialize *serialize, const FcFontSet * s);
722     
723 /* fcgram.y */
724 int
725 FcConfigparse (void);
726
727 int
728 FcConfigwrap (void);
729     
730 void
731 FcConfigerror (char *fmt, ...);
732     
733 char *
734 FcConfigSaveField (const char *field);
735
736 void
737 FcTestDestroy (FcTest *test);
738
739 FcExpr *
740 FcExprCreateInteger (int i);
741
742 FcExpr *
743 FcExprCreateDouble (double d);
744
745 FcExpr *
746 FcExprCreateString (const FcChar8 *s);
747
748 FcExpr *
749 FcExprCreateMatrix (const FcMatrix *m);
750
751 FcExpr *
752 FcExprCreateBool (FcBool b);
753
754 FcExpr *
755 FcExprCreateNil (void);
756
757 FcExpr *
758 FcExprCreateField (const char *field);
759
760 FcExpr *
761 FcExprCreateConst (const FcChar8 *constant);
762
763 FcExpr *
764 FcExprCreateOp (FcExpr *left, FcOp op, FcExpr *right);
765
766 void
767 FcExprDestroy (FcExpr *e);
768
769 void
770 FcEditDestroy (FcEdit *e);
771
772 /* fcinit.c */
773
774 void
775 FcMemReport (void);
776
777 void
778 FcMemAlloc (int kind, int size);
779
780 void
781 FcMemFree (int kind, int size);
782
783 /* fclang.c */
784 FcLangSet *
785 FcFreeTypeLangSet (const FcCharSet  *charset, 
786                    const FcChar8    *exclusiveLang);
787
788 FcLangResult
789 FcLangCompare (const FcChar8 *s1, const FcChar8 *s2);
790     
791 const FcCharSet *
792 FcCharSetForLang (const FcChar8 *lang);
793
794 FcLangSet *
795 FcLangSetPromote (const FcChar8 *lang);
796
797 FcLangSet *
798 FcNameParseLangSet (const FcChar8 *string);
799
800 FcBool
801 FcNameUnparseLangSet (FcStrBuf *buf, const FcLangSet *ls);
802
803 /* fclist.c */
804
805 FcBool
806 FcListPatternMatchAny (const FcPattern *p,
807                        const FcPattern *font);
808
809 /* fcmatch.c */
810
811 /* fcname.c */
812
813 /*
814  * NOTE -- this ordering is part of the cache file format.
815  * It must also match the ordering in fcname.c
816  */
817
818 #define FC_FAMILY_OBJECT        1
819 #define FC_FAMILYLANG_OBJECT    2
820 #define FC_STYLE_OBJECT         3
821 #define FC_STYLELANG_OBJECT     4
822 #define FC_FULLNAME_OBJECT      5
823 #define FC_FULLNAMELANG_OBJECT  6
824 #define FC_SLANT_OBJECT         7
825 #define FC_WEIGHT_OBJECT        8
826 #define FC_WIDTH_OBJECT         9
827 #define FC_SIZE_OBJECT          10
828 #define FC_ASPECT_OBJECT        11
829 #define FC_PIXEL_SIZE_OBJECT    12
830 #define FC_SPACING_OBJECT       13
831 #define FC_FOUNDRY_OBJECT       14
832 #define FC_ANTIALIAS_OBJECT     15
833 #define FC_HINT_STYLE_OBJECT    16
834 #define FC_HINTING_OBJECT       17
835 #define FC_VERTICAL_LAYOUT_OBJECT       18
836 #define FC_AUTOHINT_OBJECT      19
837 #define FC_GLOBAL_ADVANCE_OBJECT        20
838 #define FC_FILE_OBJECT          21
839 #define FC_INDEX_OBJECT         22
840 #define FC_RASTERIZER_OBJECT    23
841 #define FC_OUTLINE_OBJECT       24
842 #define FC_SCALABLE_OBJECT      25
843 #define FC_DPI_OBJECT           26
844 #define FC_RGBA_OBJECT          27
845 #define FC_SCALE_OBJECT         28
846 #define FC_MINSPACE_OBJECT      29
847 #define FC_CHAR_WIDTH_OBJECT    30
848 #define FC_CHAR_HEIGHT_OBJECT   31
849 #define FC_MATRIX_OBJECT        32
850 #define FC_CHARSET_OBJECT       33
851 #define FC_LANG_OBJECT          34
852 #define FC_FONTVERSION_OBJECT   35
853 #define FC_CAPABILITY_OBJECT    36
854 #define FC_FONTFORMAT_OBJECT    37
855 #define FC_EMBOLDEN_OBJECT      38
856 #define FC_EMBEDDED_BITMAP_OBJECT       39
857
858 FcBool
859 FcNameBool (const FcChar8 *v, FcBool *result);
860
861 FcBool
862 FcObjectValidType (FcObject object, FcType type);
863
864 FcObject
865 FcObjectFromName (const char * name);
866
867 const char *
868 FcObjectName (FcObject object);
869
870 FcBool
871 FcObjectInit (void);
872
873 void
874 FcObjectFini (void);
875
876 #define FcObjectCompare(a, b)   ((int) a - (int) b)
877
878 /* fcpat.c */
879
880 FcValue
881 FcValueCanonicalize (const FcValue *v);
882
883 void
884 FcValueListDestroy (FcValueListPtr l);
885
886 FcPatternElt *
887 FcPatternObjectFindElt (const FcPattern *p, FcObject object);
888
889 FcPatternElt *
890 FcPatternObjectInsertElt (FcPattern *p, FcObject object);
891
892 FcBool
893 FcPatternObjectAddWithBinding  (FcPattern       *p,
894                                 FcObject        object,
895                                 FcValue         value,
896                                 FcValueBinding  binding,
897                                 FcBool          append);
898
899 FcBool
900 FcPatternObjectAdd (FcPattern *p, FcObject object, FcValue value, FcBool append);
901     
902 FcBool
903 FcPatternObjectAddWeak (FcPattern *p, FcObject object, FcValue value, FcBool append);
904     
905 FcResult
906 FcPatternObjectGet (const FcPattern *p, FcObject object, int id, FcValue *v);
907     
908 FcBool
909 FcPatternObjectDel (FcPattern *p, FcObject object);
910
911 FcBool
912 FcPatternObjectRemove (FcPattern *p, FcObject object, int id);
913
914 FcBool
915 FcPatternObjectAddInteger (FcPattern *p, FcObject object, int i);
916
917 FcBool
918 FcPatternObjectAddDouble (FcPattern *p, FcObject object, double d);
919
920 FcBool
921 FcPatternObjectAddString (FcPattern *p, FcObject object, const FcChar8 *s);
922
923 FcBool
924 FcPatternObjectAddMatrix (FcPattern *p, FcObject object, const FcMatrix *s);
925
926 FcBool
927 FcPatternObjectAddCharSet (FcPattern *p, FcObject object, const FcCharSet *c);
928
929 FcBool
930 FcPatternObjectAddBool (FcPattern *p, FcObject object, FcBool b);
931
932 FcBool
933 FcPatternObjectAddLangSet (FcPattern *p, FcObject object, const FcLangSet *ls);
934
935 FcResult
936 FcPatternObjectGetInteger (const FcPattern *p, FcObject object, int n, int *i);
937
938 FcResult
939 FcPatternObjectGetDouble (const FcPattern *p, FcObject object, int n, double *d);
940
941 FcResult
942 FcPatternObjectGetString (const FcPattern *p, FcObject object, int n, FcChar8 ** s);
943
944 FcResult
945 FcPatternObjectGetMatrix (const FcPattern *p, FcObject object, int n, FcMatrix **s);
946
947 FcResult
948 FcPatternObjectGetCharSet (const FcPattern *p, FcObject object, int n, FcCharSet **c);
949
950 FcResult
951 FcPatternObjectGetBool (const FcPattern *p, FcObject object, int n, FcBool *b);
952
953 FcResult
954 FcPatternObjectGetLangSet (const FcPattern *p, FcObject object, int n, FcLangSet **ls);
955
956 void
957 FcPatternFini (void);
958
959 FcBool
960 FcPatternAppend (FcPattern *p, FcPattern *s);
961
962 const FcChar8 *
963 FcStrStaticName (const FcChar8 *name);
964
965 FcChar32
966 FcStringHash (const FcChar8 *s);
967
968 FcBool
969 FcPatternSerializeAlloc (FcSerialize *serialize, const FcPattern *pat);
970
971 FcPattern *
972 FcPatternSerialize (FcSerialize *serialize, const FcPattern *pat);
973
974 FcBool
975 FcValueListSerializeAlloc (FcSerialize *serialize, const FcValueList *pat);
976
977 FcValueList *
978 FcValueListSerialize (FcSerialize *serialize, const FcValueList *pat);
979
980 /* fcrender.c */
981
982 /* fcmatrix.c */
983
984 extern const FcMatrix    FcIdentityMatrix;
985
986 void
987 FcMatrixFree (FcMatrix *mat);
988
989 /* fcstr.c */
990 void
991 FcStrSetSort (FcStrSet * set);
992
993 FcChar8 *
994 FcStrPlus (const FcChar8 *s1, const FcChar8 *s2);
995     
996 void
997 FcStrFree (FcChar8 *s);
998
999 void
1000 FcStrBufInit (FcStrBuf *buf, FcChar8 *init, int size);
1001
1002 void
1003 FcStrBufDestroy (FcStrBuf *buf);
1004
1005 FcChar8 *
1006 FcStrBufDone (FcStrBuf *buf);
1007
1008 FcBool
1009 FcStrBufChar (FcStrBuf *buf, FcChar8 c);
1010
1011 FcBool
1012 FcStrBufString (FcStrBuf *buf, const FcChar8 *s);
1013
1014 FcBool
1015 FcStrBufData (FcStrBuf *buf, const FcChar8 *s, int len);
1016
1017 int
1018 FcStrCmpIgnoreBlanksAndCase (const FcChar8 *s1, const FcChar8 *s2);
1019
1020 const FcChar8 *
1021 FcStrContainsIgnoreBlanksAndCase (const FcChar8 *s1, const FcChar8 *s2);
1022
1023 const FcChar8 *
1024 FcStrContainsIgnoreCase (const FcChar8 *s1, const FcChar8 *s2);
1025
1026 FcBool
1027 FcStrUsesHome (const FcChar8 *s);
1028
1029 FcChar8 *
1030 FcStrLastSlash (const FcChar8  *path);
1031
1032 FcChar32
1033 FcStrHashIgnoreCase (const FcChar8 *s);
1034
1035 FcChar8 *
1036 FcStrCanonFilename (const FcChar8 *s);
1037
1038 FcBool
1039 FcStrSerializeAlloc (FcSerialize *serialize, const FcChar8 *str);
1040
1041 FcChar8 *
1042 FcStrSerialize (FcSerialize *serialize, const FcChar8 *str);
1043
1044 #endif /* _FC_INT_H_ */