]> git.wh0rd.org - fontconfig.git/blame_incremental - src/fcint.h
Fix fc-lang to use new charset freezer API.
[fontconfig.git] / src / fcint.h
... / ...
CommitLineData
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
59#ifdef _WIN32
60#define FC_SEARCH_PATH_SEPARATOR ';'
61#else
62#define FC_SEARCH_PATH_SEPARATOR ':'
63#endif
64
65#define FC_DBG_MATCH 1
66#define FC_DBG_MATCHV 2
67#define FC_DBG_EDIT 4
68#define FC_DBG_FONTSET 8
69#define FC_DBG_CACHE 16
70#define FC_DBG_CACHEV 32
71#define FC_DBG_PARSE 64
72#define FC_DBG_SCAN 128
73#define FC_DBG_SCANV 256
74#define FC_DBG_MEMORY 512
75#define FC_DBG_CONFIG 1024
76#define FC_DBG_LANGSET 2048
77#define FC_DBG_OBJTYPES 4096
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
116typedef 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
166typedef struct _FcValueList *FcValueListPtr;
167
168typedef struct _FcValueList {
169 struct _FcValueList *next;
170 FcValue value;
171 FcValueBinding binding;
172} FcValueList;
173
174#define FcValueListNext(vl) FcPointerMember(vl,next,FcValueList)
175
176typedef int FcObject;
177
178typedef 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 */
185typedef struct _FcPatternElt {
186 FcObject object;
187 FcValueList *values;
188} FcPatternElt;
189
190#define FcPatternEltValues(pe) FcPointerMember(pe,values,FcValueList)
191
192struct _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
209typedef 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
224typedef 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
241typedef enum _FcQual {
242 FcQualAny, FcQualAll, FcQualFirst, FcQualNotFirst
243} FcQual;
244
245#define FcMatchDefault ((FcMatchKind) -1)
246
247typedef struct _FcTest {
248 struct _FcTest *next;
249 FcMatchKind kind;
250 FcQual qual;
251 FcObject object;
252 FcOp op;
253 FcExpr *expr;
254} FcTest;
255
256typedef struct _FcEdit {
257 struct _FcEdit *next;
258 FcObject object;
259 FcOp op;
260 FcExpr *expr;
261 FcValueBinding binding;
262} FcEdit;
263
264typedef struct _FcSubst {
265 struct _FcSubst *next;
266 FcTest *test;
267 FcEdit *edit;
268} FcSubst;
269
270typedef struct _FcCharLeaf {
271 FcChar32 map[256/32];
272} FcCharLeaf;
273
274#define FC_REF_CONSTANT -1
275
276struct _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
289struct _FcStrSet {
290 int ref; /* reference count */
291 int num;
292 int size;
293 FcChar8 **strs;
294};
295
296struct _FcStrList {
297 FcStrSet *set;
298 int n;
299};
300
301typedef struct _FcStrBuf {
302 FcChar8 *buf;
303 FcBool allocated;
304 FcBool failed;
305 int len;
306 int size;
307} FcStrBuf;
308
309typedef struct _FcCache {
310 int magic; /* FC_CACHE_MAGIC_MMAP or FC_CACHE_ALLOC */
311 int version; /* FC_CACHE_CONTENT_VERSION */
312 intptr_t size; /* size of file */
313 intptr_t dir; /* offset to dir name */
314 intptr_t dirs; /* offset to subdirs */
315 int dirs_count; /* number of subdir strings */
316 intptr_t set; /* offset to font set */
317} FcCache;
318
319#define FcCacheDir(c) FcOffsetMember(c,dir,FcChar8)
320#define FcCacheDirs(c) FcOffsetMember(c,dirs,intptr_t)
321#define FcCacheSet(c) FcOffsetMember(c,set,FcFontSet)
322#define FcCacheSubdir(c,i) FcOffsetToPtr (FcCacheDirs(cache),\
323 FcCacheDirs(cache)[i], \
324 FcChar8)
325
326/*
327 * Used while constructing a directory cache object
328 */
329
330#define FC_SERIALIZE_HASH_SIZE 8191
331
332typedef struct _FcSerializeBucket {
333 struct _FcSerializeBucket *next;
334 const void *object;
335 intptr_t offset;
336} FcSerializeBucket;
337
338typedef struct _FcCharSetFreezer FcCharSetFreezer;
339
340typedef struct _FcSerialize {
341 intptr_t size;
342 FcCharSetFreezer *cs_freezer;
343 void *linear;
344 FcSerializeBucket *buckets[FC_SERIALIZE_HASH_SIZE];
345} FcSerialize;
346
347/*
348 * To map adobe glyph names to unicode values, a precomputed hash
349 * table is used
350 */
351
352typedef struct _FcGlyphName {
353 FcChar32 ucs; /* unicode value */
354 FcChar8 name[1]; /* name extends beyond struct */
355} FcGlyphName;
356
357/*
358 * To perform case-insensitive string comparisons, a table
359 * is used which holds three different kinds of folding data.
360 *
361 * The first is a range of upper case values mapping to a range
362 * of their lower case equivalents. Within each range, the offset
363 * between upper and lower case is constant.
364 *
365 * The second is a range of upper case values which are interleaved
366 * with their lower case equivalents.
367 *
368 * The third is a set of raw unicode values mapping to a list
369 * of unicode values for comparison purposes. This allows conversion
370 * of ß to "ss" so that SS, ss and ß all match. A separate array
371 * holds the list of unicode values for each entry.
372 *
373 * These are packed into a single table. Using a binary search,
374 * the appropriate entry can be located.
375 */
376
377#define FC_CASE_FOLD_RANGE 0
378#define FC_CASE_FOLD_EVEN_ODD 1
379#define FC_CASE_FOLD_FULL 2
380
381typedef struct _FcCaseFold {
382 FcChar32 upper;
383 FcChar16 method : 2;
384 FcChar16 count : 14;
385 short offset; /* lower - upper for RANGE, table id for FULL */
386} FcCaseFold;
387
388#define FC_MAX_FILE_LEN 4096
389
390/* XXX remove these when we're ready */
391
392#define fc_value_string(v) FcValueString(v)
393#define fc_value_charset(v) FcValueCharSet(v)
394#define fc_value_langset(v) FcValueLangSet(v)
395#define fc_storage_type(v) ((v)->type)
396
397#define fc_alignof(type) offsetof (struct { char c; type member; }, member)
398
399#define FC_CACHE_MAGIC_MMAP 0xFC02FC04
400#define FC_CACHE_MAGIC_ALLOC 0xFC02FC05
401#define FC_CACHE_CONTENT_VERSION 1
402
403struct _FcAtomic {
404 FcChar8 *file; /* original file name */
405 FcChar8 *new; /* temp file name -- write data here */
406 FcChar8 *lck; /* lockfile name (used for locking) */
407 FcChar8 *tmp; /* tmpfile name (used for locking) */
408};
409
410struct _FcBlanks {
411 int nblank;
412 int sblank;
413 FcChar32 *blanks;
414};
415
416typedef struct _FcCacheList {
417 struct _FcCacheList *next;
418 FcCache *cache;
419} FcCacheList;
420
421struct _FcConfig {
422 /*
423 * File names loaded from the configuration -- saved here as the
424 * cache file must be consulted before the directories are scanned,
425 * and those directives may occur in any order
426 */
427 FcStrSet *configDirs; /* directories to scan for fonts */
428 /*
429 * Set of allowed blank chars -- used to
430 * trim fonts of bogus glyphs
431 */
432 FcBlanks *blanks;
433 /*
434 * List of directories containing fonts,
435 * built by recursively scanning the set
436 * of configured directories
437 */
438 FcStrSet *fontDirs;
439 /*
440 * List of directories containing cache files.
441 */
442 FcStrSet *cacheDirs;
443 /*
444 * Names of all of the configuration files used
445 * to create this configuration
446 */
447 FcStrSet *configFiles; /* config files loaded */
448 /*
449 * Substitution instructions for patterns and fonts;
450 * maxObjects is used to allocate appropriate intermediate storage
451 * while performing a whole set of substitutions
452 */
453 FcSubst *substPattern; /* substitutions for patterns */
454 FcSubst *substFont; /* substitutions for fonts */
455 int maxObjects; /* maximum number of tests in all substs */
456 /*
457 * List of patterns used to control font file selection
458 */
459 FcStrSet *acceptGlobs;
460 FcStrSet *rejectGlobs;
461 FcFontSet *acceptPatterns;
462 FcFontSet *rejectPatterns;
463 /*
464 * The set of fonts loaded from the listed directories; the
465 * order within the set does not determine the font selection,
466 * except in the case of identical matches in which case earlier fonts
467 * match preferrentially
468 */
469 FcFontSet *fonts[FcSetApplication + 1];
470 /*
471 * Font cache information is mapped from cache files
472 * the configuration is destroyed, the files need to be unmapped
473 */
474 FcCacheList *caches;
475 /*
476 * Fontconfig can periodically rescan the system configuration
477 * and font directories. This rescanning occurs when font
478 * listing requests are made, but no more often than rescanInterval
479 * seconds apart.
480 */
481 time_t rescanTime; /* last time information was scanned */
482 int rescanInterval; /* interval between scans */
483};
484
485extern FcConfig *_fcConfig;
486
487typedef struct _FcFileTime {
488 time_t time;
489 FcBool set;
490} FcFileTime;
491
492typedef struct _FcCharMap FcCharMap;
493
494/* watch out; assumes that v is void * -PL */
495#define ALIGN(v,type) ((void *)(((uintptr_t)(v) + fc_alignof(type) - 1) & ~(fc_alignof(type) - 1)))
496
497/* fcblanks.c */
498
499/* fccache.c */
500
501FcBool
502FcDirCacheUnlink (const FcChar8 *dir, FcConfig *config);
503
504void
505FcDirCacheUnload (FcCache *cache);
506
507FcCache *
508FcDirCacheScan (const FcChar8 *dir, FcConfig *config);
509
510FcCache *
511FcDirCacheLoad (const FcChar8 *dir, FcConfig *config, FcChar8 **cache_file);
512
513FcCache *
514FcDirCacheLoadFile (const FcChar8 *cache_file, struct stat *file_stat);
515
516FcBool
517FcDirCacheValid (const FcChar8 *dir);
518
519FcCache *
520FcDirCacheBuild (FcFontSet *set, const FcChar8 *dir, FcStrSet *dirs);
521
522FcBool
523FcDirCacheWrite (FcCache *cache, FcConfig *config);
524
525/* fccfg.c */
526
527FcBool
528FcConfigAddConfigDir (FcConfig *config,
529 const FcChar8 *d);
530
531FcBool
532FcConfigAddFontDir (FcConfig *config,
533 const FcChar8 *d);
534
535FcBool
536FcConfigAddDir (FcConfig *config,
537 const FcChar8 *d);
538
539FcBool
540FcConfigAddCacheDir (FcConfig *config,
541 const FcChar8 *d);
542
543FcStrList *
544FcConfigGetCacheDirs (FcConfig *config);
545
546FcBool
547FcConfigAddConfigFile (FcConfig *config,
548 const FcChar8 *f);
549
550FcBool
551FcConfigAddBlank (FcConfig *config,
552 FcChar32 blank);
553
554FcBool
555FcConfigAddEdit (FcConfig *config,
556 FcTest *test,
557 FcEdit *edit,
558 FcMatchKind kind);
559
560void
561FcConfigSetFonts (FcConfig *config,
562 FcFontSet *fonts,
563 FcSetName set);
564
565FcBool
566FcConfigCompareValue (const FcValue *m,
567 FcOp op,
568 const FcValue *v);
569
570FcBool
571FcConfigGlobAdd (FcConfig *config,
572 const FcChar8 *glob,
573 FcBool accept);
574
575FcBool
576FcConfigAcceptFilename (FcConfig *config,
577 const FcChar8 *filename);
578
579FcBool
580FcConfigPatternsAdd (FcConfig *config,
581 FcPattern *pattern,
582 FcBool accept);
583
584FcBool
585FcConfigAcceptFont (FcConfig *config,
586 const FcPattern *font);
587
588FcFileTime
589FcConfigModifiedTime (FcConfig *config);
590
591FcBool
592FcConfigAddCache (FcConfig *config, FcCache *cache);
593
594/* fcserialize.c */
595intptr_t
596FcAlignSize (intptr_t size);
597
598FcSerialize *
599FcSerializeCreate (void);
600
601void
602FcSerializeDestroy (FcSerialize *serialize);
603
604FcBool
605FcSerializeAlloc (FcSerialize *serialize, const void *object, int size);
606
607intptr_t
608FcSerializeReserve (FcSerialize *serialize, int size);
609
610intptr_t
611FcSerializeOffset (FcSerialize *serialize, const void *object);
612
613void *
614FcSerializePtr (FcSerialize *serialize, const void *object);
615
616FcBool
617FcLangSetSerializeAlloc (FcSerialize *serialize, const FcLangSet *l);
618
619FcLangSet *
620FcLangSetSerialize(FcSerialize *serialize, const FcLangSet *l);
621
622/* fccharset.c */
623void
624FcLangCharSetPopulate (void);
625
626FcCharSetFreezer *
627FcCharSetFreezerCreate (void);
628
629const FcCharSet *
630FcCharSetFreeze (FcCharSetFreezer *freezer, const FcCharSet *fcs);
631
632void
633FcCharSetFreezerDestroy (FcCharSetFreezer *freezer);
634
635FcBool
636FcNameUnparseCharSet (FcStrBuf *buf, const FcCharSet *c);
637
638FcCharSet *
639FcNameParseCharSet (FcChar8 *string);
640
641FcCharLeaf *
642FcCharSetFindLeafCreate (FcCharSet *fcs, FcChar32 ucs4);
643
644FcBool
645FcCharSetSerializeAlloc(FcSerialize *serialize, const FcCharSet *cs);
646
647FcCharSet *
648FcCharSetSerialize(FcSerialize *serialize, const FcCharSet *cs);
649
650FcChar16 *
651FcCharSetGetNumbers(const FcCharSet *c);
652
653/* fcdbg.c */
654void
655FcValueListPrint (const FcValueListPtr l);
656
657void
658FcLangSetPrint (const FcLangSet *ls);
659
660void
661FcOpPrint (FcOp op);
662
663void
664FcTestPrint (const FcTest *test);
665
666void
667FcExprPrint (const FcExpr *expr);
668
669void
670FcEditPrint (const FcEdit *edit);
671
672void
673FcSubstPrint (const FcSubst *subst);
674
675void
676FcCharSetPrint (const FcCharSet *c);
677
678extern int FcDebugVal;
679
680static inline int
681FcDebug (void) { return FcDebugVal; }
682
683void
684FcInitDebug (void);
685
686/* fcdefault.c */
687FcChar8 *
688FcGetDefaultLang (void);
689
690/* fcdir.c */
691
692FcBool
693FcFileIsDir (const FcChar8 *file);
694
695FcBool
696FcFileScanConfig (FcFontSet *set,
697 FcStrSet *dirs,
698 FcBlanks *blanks,
699 const FcChar8 *file,
700 FcConfig *config);
701
702FcBool
703FcDirScanConfig (FcFontSet *set,
704 FcStrSet *dirs,
705 FcBlanks *blanks,
706 const FcChar8 *dir,
707 FcBool force,
708 FcConfig *config);
709
710FcCache *
711FcDirCacheRead (const FcChar8 *dir, FcBool force, FcConfig *config);
712
713/* fcfont.c */
714int
715FcFontDebug (void);
716
717/* fcfreetype.c */
718FcBool
719FcFreeTypeIsExclusiveLang (const FcChar8 *lang);
720
721FcBool
722FcFreeTypeHasLang (FcPattern *pattern, const FcChar8 *lang);
723
724FcChar32
725FcFreeTypeUcs4ToPrivate (FcChar32 ucs4, const FcCharMap *map);
726
727FcChar32
728FcFreeTypePrivateToUcs4 (FcChar32 private, const FcCharMap *map);
729
730const FcCharMap *
731FcFreeTypeGetPrivateMap (FT_Encoding encoding);
732
733/* fcfs.c */
734
735FcBool
736FcFontSetSerializeAlloc (FcSerialize *serialize, const FcFontSet *s);
737
738FcFontSet *
739FcFontSetSerialize (FcSerialize *serialize, const FcFontSet * s);
740
741/* fcgram.y */
742int
743FcConfigparse (void);
744
745int
746FcConfigwrap (void);
747
748void
749FcConfigerror (char *fmt, ...);
750
751char *
752FcConfigSaveField (const char *field);
753
754void
755FcTestDestroy (FcTest *test);
756
757FcExpr *
758FcExprCreateInteger (int i);
759
760FcExpr *
761FcExprCreateDouble (double d);
762
763FcExpr *
764FcExprCreateString (const FcChar8 *s);
765
766FcExpr *
767FcExprCreateMatrix (const FcMatrix *m);
768
769FcExpr *
770FcExprCreateBool (FcBool b);
771
772FcExpr *
773FcExprCreateNil (void);
774
775FcExpr *
776FcExprCreateField (const char *field);
777
778FcExpr *
779FcExprCreateConst (const FcChar8 *constant);
780
781FcExpr *
782FcExprCreateOp (FcExpr *left, FcOp op, FcExpr *right);
783
784void
785FcExprDestroy (FcExpr *e);
786
787void
788FcEditDestroy (FcEdit *e);
789
790/* fcinit.c */
791
792void
793FcMemReport (void);
794
795void
796FcMemAlloc (int kind, int size);
797
798void
799FcMemFree (int kind, int size);
800
801/* fclang.c */
802FcLangSet *
803FcFreeTypeLangSet (const FcCharSet *charset,
804 const FcChar8 *exclusiveLang);
805
806FcLangResult
807FcLangCompare (const FcChar8 *s1, const FcChar8 *s2);
808
809const FcCharSet *
810FcCharSetForLang (const FcChar8 *lang);
811
812FcLangSet *
813FcLangSetPromote (const FcChar8 *lang);
814
815FcLangSet *
816FcNameParseLangSet (const FcChar8 *string);
817
818FcBool
819FcNameUnparseLangSet (FcStrBuf *buf, const FcLangSet *ls);
820
821FcChar8 *
822FcNameUnparseEscaped (FcPattern *pat, FcBool escape);
823
824/* fclist.c */
825
826FcBool
827FcListPatternMatchAny (const FcPattern *p,
828 const FcPattern *font);
829
830/* fcmatch.c */
831
832/* fcname.c */
833
834/*
835 * NOTE -- this ordering is part of the cache file format.
836 * It must also match the ordering in fcname.c
837 */
838
839#define FC_FAMILY_OBJECT 1
840#define FC_FAMILYLANG_OBJECT 2
841#define FC_STYLE_OBJECT 3
842#define FC_STYLELANG_OBJECT 4
843#define FC_FULLNAME_OBJECT 5
844#define FC_FULLNAMELANG_OBJECT 6
845#define FC_SLANT_OBJECT 7
846#define FC_WEIGHT_OBJECT 8
847#define FC_WIDTH_OBJECT 9
848#define FC_SIZE_OBJECT 10
849#define FC_ASPECT_OBJECT 11
850#define FC_PIXEL_SIZE_OBJECT 12
851#define FC_SPACING_OBJECT 13
852#define FC_FOUNDRY_OBJECT 14
853#define FC_ANTIALIAS_OBJECT 15
854#define FC_HINT_STYLE_OBJECT 16
855#define FC_HINTING_OBJECT 17
856#define FC_VERTICAL_LAYOUT_OBJECT 18
857#define FC_AUTOHINT_OBJECT 19
858#define FC_GLOBAL_ADVANCE_OBJECT 20
859#define FC_FILE_OBJECT 21
860#define FC_INDEX_OBJECT 22
861#define FC_RASTERIZER_OBJECT 23
862#define FC_OUTLINE_OBJECT 24
863#define FC_SCALABLE_OBJECT 25
864#define FC_DPI_OBJECT 26
865#define FC_RGBA_OBJECT 27
866#define FC_SCALE_OBJECT 28
867#define FC_MINSPACE_OBJECT 29
868#define FC_CHAR_WIDTH_OBJECT 30
869#define FC_CHAR_HEIGHT_OBJECT 31
870#define FC_MATRIX_OBJECT 32
871#define FC_CHARSET_OBJECT 33
872#define FC_LANG_OBJECT 34
873#define FC_FONTVERSION_OBJECT 35
874#define FC_CAPABILITY_OBJECT 36
875#define FC_FONTFORMAT_OBJECT 37
876#define FC_EMBOLDEN_OBJECT 38
877#define FC_EMBEDDED_BITMAP_OBJECT 39
878
879FcBool
880FcNameBool (const FcChar8 *v, FcBool *result);
881
882FcBool
883FcObjectValidType (FcObject object, FcType type);
884
885FcObject
886FcObjectFromName (const char * name);
887
888const char *
889FcObjectName (FcObject object);
890
891FcBool
892FcObjectInit (void);
893
894void
895FcObjectFini (void);
896
897#define FcObjectCompare(a, b) ((int) a - (int) b)
898
899/* fcpat.c */
900
901FcValue
902FcValueCanonicalize (const FcValue *v);
903
904void
905FcValueListDestroy (FcValueListPtr l);
906
907FcPatternElt *
908FcPatternObjectFindElt (const FcPattern *p, FcObject object);
909
910FcPatternElt *
911FcPatternObjectInsertElt (FcPattern *p, FcObject object);
912
913FcBool
914FcPatternObjectAddWithBinding (FcPattern *p,
915 FcObject object,
916 FcValue value,
917 FcValueBinding binding,
918 FcBool append);
919
920FcBool
921FcPatternObjectAdd (FcPattern *p, FcObject object, FcValue value, FcBool append);
922
923FcBool
924FcPatternObjectAddWeak (FcPattern *p, FcObject object, FcValue value, FcBool append);
925
926FcResult
927FcPatternObjectGet (const FcPattern *p, FcObject object, int id, FcValue *v);
928
929FcBool
930FcPatternObjectDel (FcPattern *p, FcObject object);
931
932FcBool
933FcPatternObjectRemove (FcPattern *p, FcObject object, int id);
934
935FcBool
936FcPatternObjectAddInteger (FcPattern *p, FcObject object, int i);
937
938FcBool
939FcPatternObjectAddDouble (FcPattern *p, FcObject object, double d);
940
941FcBool
942FcPatternObjectAddString (FcPattern *p, FcObject object, const FcChar8 *s);
943
944FcBool
945FcPatternObjectAddMatrix (FcPattern *p, FcObject object, const FcMatrix *s);
946
947FcBool
948FcPatternObjectAddCharSet (FcPattern *p, FcObject object, const FcCharSet *c);
949
950FcBool
951FcPatternObjectAddBool (FcPattern *p, FcObject object, FcBool b);
952
953FcBool
954FcPatternObjectAddLangSet (FcPattern *p, FcObject object, const FcLangSet *ls);
955
956FcResult
957FcPatternObjectGetInteger (const FcPattern *p, FcObject object, int n, int *i);
958
959FcResult
960FcPatternObjectGetDouble (const FcPattern *p, FcObject object, int n, double *d);
961
962FcResult
963FcPatternObjectGetString (const FcPattern *p, FcObject object, int n, FcChar8 ** s);
964
965FcResult
966FcPatternObjectGetMatrix (const FcPattern *p, FcObject object, int n, FcMatrix **s);
967
968FcResult
969FcPatternObjectGetCharSet (const FcPattern *p, FcObject object, int n, FcCharSet **c);
970
971FcResult
972FcPatternObjectGetBool (const FcPattern *p, FcObject object, int n, FcBool *b);
973
974FcResult
975FcPatternObjectGetLangSet (const FcPattern *p, FcObject object, int n, FcLangSet **ls);
976
977void
978FcPatternFini (void);
979
980FcBool
981FcPatternAppend (FcPattern *p, FcPattern *s);
982
983const FcChar8 *
984FcStrStaticName (const FcChar8 *name);
985
986FcChar32
987FcStringHash (const FcChar8 *s);
988
989FcBool
990FcPatternSerializeAlloc (FcSerialize *serialize, const FcPattern *pat);
991
992FcPattern *
993FcPatternSerialize (FcSerialize *serialize, const FcPattern *pat);
994
995FcBool
996FcValueListSerializeAlloc (FcSerialize *serialize, const FcValueList *pat);
997
998FcValueList *
999FcValueListSerialize (FcSerialize *serialize, const FcValueList *pat);
1000
1001/* fcrender.c */
1002
1003/* fcmatrix.c */
1004
1005extern const FcMatrix FcIdentityMatrix;
1006
1007void
1008FcMatrixFree (FcMatrix *mat);
1009
1010/* fcstr.c */
1011void
1012FcStrSetSort (FcStrSet * set);
1013
1014FcChar8 *
1015FcStrPlus (const FcChar8 *s1, const FcChar8 *s2);
1016
1017void
1018FcStrFree (FcChar8 *s);
1019
1020void
1021FcStrBufInit (FcStrBuf *buf, FcChar8 *init, int size);
1022
1023void
1024FcStrBufDestroy (FcStrBuf *buf);
1025
1026FcChar8 *
1027FcStrBufDone (FcStrBuf *buf);
1028
1029FcBool
1030FcStrBufChar (FcStrBuf *buf, FcChar8 c);
1031
1032FcBool
1033FcStrBufString (FcStrBuf *buf, const FcChar8 *s);
1034
1035FcBool
1036FcStrBufData (FcStrBuf *buf, const FcChar8 *s, int len);
1037
1038int
1039FcStrCmpIgnoreBlanksAndCase (const FcChar8 *s1, const FcChar8 *s2);
1040
1041const FcChar8 *
1042FcStrContainsIgnoreBlanksAndCase (const FcChar8 *s1, const FcChar8 *s2);
1043
1044const FcChar8 *
1045FcStrContainsIgnoreCase (const FcChar8 *s1, const FcChar8 *s2);
1046
1047FcBool
1048FcStrUsesHome (const FcChar8 *s);
1049
1050FcChar8 *
1051FcStrLastSlash (const FcChar8 *path);
1052
1053FcChar32
1054FcStrHashIgnoreCase (const FcChar8 *s);
1055
1056FcChar8 *
1057FcStrCanonFilename (const FcChar8 *s);
1058
1059FcBool
1060FcStrSerializeAlloc (FcSerialize *serialize, const FcChar8 *str);
1061
1062FcChar8 *
1063FcStrSerialize (FcSerialize *serialize, const FcChar8 *str);
1064
1065#endif /* _FC_INT_H_ */