diff options
author | Keith Packard <keithp@keithp.com> | 2002-08-11 18:11:04 +0000 |
---|---|---|
committer | Keith Packard <keithp@keithp.com> | 2002-08-11 18:11:04 +0000 |
commit | 938bc63358c09b9fd3709e8f914870f906361594 (patch) | |
tree | 210e4c0903f76cd95e5202f3da198b0a00fcfae1 | |
parent | 80a7d664395d62cc335ac93b9918efebca00c117 (diff) |
Fix weird first/not-first lameness in font matches, replacing with targetrc2fcpackage_rc2
qualifiers on test elements. Update library manual page.
-rw-r--r-- | fontconfig/fcprivate.h | 5 | ||||
-rw-r--r-- | fontconfig/fontconfig.h | 23 | ||||
-rw-r--r-- | fonts.conf.in | 9 | ||||
-rw-r--r-- | fonts.dtd | 4 | ||||
-rw-r--r-- | src/fccfg.c | 142 | ||||
-rw-r--r-- | src/fcdbg.c | 29 | ||||
-rw-r--r-- | src/fcint.h | 19 | ||||
-rw-r--r-- | src/fclist.c | 4 | ||||
-rw-r--r-- | src/fcmatch.c | 19 | ||||
-rw-r--r-- | src/fcname.c | 4 | ||||
-rw-r--r-- | src/fcpat.c | 43 | ||||
-rw-r--r-- | src/fcxml.c | 33 | ||||
-rw-r--r-- | src/fontconfig.man | 332 |
13 files changed, 510 insertions, 156 deletions
diff --git a/fontconfig/fcprivate.h b/fontconfig/fcprivate.h index 16ea543e..3754efa7 100644 --- a/fontconfig/fcprivate.h +++ b/fontconfig/fcprivate.h @@ -1,5 +1,5 @@ /* - * $XFree86: xc/lib/fontconfig/fontconfig/fcprivate.h,v 1.2 2002/02/15 06:01:27 keithp Exp $ + * $XFree86: xc/lib/fontconfig/fontconfig/fcprivate.h,v 1.3 2002/05/31 23:21:24 keithp Exp $ * * Copyright © 2001 Keith Packard, member of The XFree86 Project, Inc. * @@ -72,6 +72,9 @@ break; \ case FcTypeFTFace: \ __v__.u.f = va_arg (va, FT_Face); \ + break; \ + case FcTypePattern: \ + __v__.u.p = va_arg (va, FcPattern *); \ } \ if (!FcPatternAdd (__p__, __o__, __v__, FcTrue)) \ goto _FcPatternVapBuild_bail1; \ diff --git a/fontconfig/fontconfig.h b/fontconfig/fontconfig.h index faa0554c..b5fc1f67 100644 --- a/fontconfig/fontconfig.h +++ b/fontconfig/fontconfig.h @@ -71,6 +71,7 @@ typedef int FcBool; #define FC_SOURCE "source" /* String (X11, freetype) */ #define FC_CHARSET "charset" /* CharSet */ #define FC_LANG "lang" /* String OS/2 CodePageRange */ +#define FC_PATTERN "pattern" /* FcPattern */ #define FC_DIR_CACHE_FILE "fonts.cache" #define FC_USER_CACHE_FILE ".fonts.cache" @@ -109,7 +110,8 @@ typedef enum _FcType { FcTypeBool, FcTypeMatrix, FcTypeCharSet, - FcTypeFTFace + FcTypeFTFace, + FcTypePattern } FcType; typedef struct _FcMatrix { @@ -141,6 +143,8 @@ typedef enum _FcResult { FcResultMatch, FcResultNoMatch, FcResultTypeMismatch, FcResultNoId } FcResult; +typedef struct _FcPattern FcPattern; + typedef struct _FcValue { FcType type; union { @@ -151,11 +155,10 @@ typedef struct _FcValue { const FcMatrix *m; const FcCharSet *c; void *f; + const FcPattern *p; } u; } FcValue; -typedef struct _FcPattern FcPattern; - typedef struct _FcFontSet { int nfont; int sfont; @@ -169,7 +172,7 @@ typedef struct _FcObjectSet { } FcObjectSet; typedef enum _FcMatchKind { - FcMatchPattern, FcMatchFont + FcMatchPattern, FcMatchFont } FcMatchKind; typedef enum _FcSetName { @@ -336,13 +339,13 @@ FcCharSetNextPage (const FcCharSet *a, /* fcdbg.c */ void -FcValuePrint (FcValue v); +FcValuePrint (const FcValue v); void -FcPatternPrint (FcPattern *p); +FcPatternPrint (const FcPattern *p); void -FcFontSetPrint (FcFontSet *s); +FcFontSetPrint (const FcFontSet *s); /* fcdefault.c */ void @@ -602,6 +605,9 @@ FcPatternAddCharSet (FcPattern *p, const char *object, const FcCharSet *c); FcBool FcPatternAddBool (FcPattern *p, const char *object, FcBool b); +FcBool +FcPatternAddPattern (FcPattern *p, const char *object, const FcPattern *pp); + FcResult FcPatternGetInteger (FcPattern *p, const char *object, int n, int *i); @@ -620,6 +626,9 @@ FcPatternGetCharSet (FcPattern *p, const char *object, int n, FcCharSet **c); FcResult FcPatternGetBool (FcPattern *p, const char *object, int n, FcBool *b); +FcResult +FcPatternGetPattern (FcPattern *p, const char *object, int n, FcPattern **pp); + FcPattern * FcPatternVaBuild (FcPattern *orig, va_list va); diff --git a/fonts.conf.in b/fonts.conf.in index baccc8af..48065607 100644 --- a/fonts.conf.in +++ b/fonts.conf.in @@ -128,6 +128,11 @@ <include ignore_missing="yes">~/.fonts.conf</include> <!-- + Load local system customization file +--> + <include ignore_missing="yes">local.conf</include> + +<!-- Alias well known font names to available TrueType fonts --> <alias> @@ -197,11 +202,11 @@ <match target="font"> <!-- check to see if the font is roman --> - <test qual="first" name="slant"> + <test name="slant"> <const>roman</const> </test> <!-- check to see if the pattern requested non-roman --> - <test qual="not_first" name="slant" compare="not_eq"> + <test target="pattern" name="slant" compare="not_eq"> <const>roman</const> </test> <!-- multiply the matrix to slant the font --> @@ -112,11 +112,15 @@ if 'qual' is 'first', then the match succeeds only if the first value matches. if 'qual' is 'not_first', then the match succeeds only if any value other than the first matches. + For match elements with target=font, if test 'target' is 'pattern', + then the test is applied to the pattern used in matching rather than + to the resulting font. --> <!ELEMENT test (%expr;)*> <!ATTLIST test qual (any|all|first|not_first) "any" name CDATA #REQUIRED + target (pattern|font|default) "default" compare (eq|not_eq|less|less_eq|more|more_eq) "eq"> <!-- diff --git a/src/fccfg.c b/src/fccfg.c index 478f5a6f..328b1ac5 100644 --- a/src/fccfg.c +++ b/src/fccfg.c @@ -1,5 +1,5 @@ /* - * $XFree86: xc/lib/fontconfig/src/fccfg.c,v 1.15 2002/06/21 06:14:45 keithp Exp $ + * $XFree86: xc/lib/fontconfig/src/fccfg.c,v 1.18 2002/07/31 01:36:37 keithp Exp $ * * Copyright © 2000 Keith Packard, member of The XFree86 Project, Inc. * @@ -438,16 +438,20 @@ FcConfigAddEdit (FcConfig *config, subst->next = 0; subst->test = test; subst->edit = edit; - if (FcDebug () & FC_DBG_EDIT) - { - printf ("Add Subst "); - FcSubstPrint (subst); - } num = 0; for (t = test; t; t = t->next) + { + if (t->kind == FcMatchDefault) + t->kind = kind; num++; + } if (config->maxObjects < num) config->maxObjects = num; + if (FcDebug () & FC_DBG_EDIT) + { + printf ("Add Subst "); + FcSubstPrint (subst); + } return FcTrue; } @@ -483,7 +487,6 @@ FcConfigCompareValue (FcValue m, v = FcConfigPromote (v, m); if (m.type == v.type) { - ret = FcFalse; switch (m.type) { case FcTypeInteger: break; /* FcConfigPromote prevents this from happening */ @@ -588,6 +591,19 @@ FcConfigCompareValue (FcValue m, default: break; } + break; + case FcTypePattern: + switch (op) { + case FcOpEqual: + ret = FcPatternEqual (m.u.p, v.u.p); + break; + case FcOpNotEqual: + ret = !FcPatternEqual (m.u.p, v.u.p); + break; + default: + break; + } + break; } } else @@ -658,15 +674,22 @@ FcConfigEvaluate (FcPattern *p, FcExpr *e) v.type = FcTypeVoid; FcValueDestroy (vl); break; - case FcOpOr: - case FcOpAnd: - case FcOpEqual: case FcOpContains: case FcOpNotEqual: case FcOpLess: case FcOpLessEqual: case FcOpMore: case FcOpMoreEqual: + vl = FcConfigEvaluate (p, e->u.tree.left); + vr = FcConfigEvaluate (p, e->u.tree.right); + v.type = FcTypeBool; + v.u.b = FcConfigCompareValue (vl, e->op, vr); + FcValueDestroy (vl); + FcValueDestroy (vr); + break; + case FcOpOr: + case FcOpAnd: + case FcOpEqual: case FcOpPlus: case FcOpMinus: case FcOpTimes: @@ -696,31 +719,6 @@ FcConfigEvaluate (FcPattern *p, FcExpr *e) v.type = FcTypeDouble; v.u.d = vl.u.d / vr.u.d; break; - case FcOpEqual: - case FcOpContains: - v.type = FcTypeBool; - v.u.b = vl.u.d == vr.u.d; - break; - case FcOpNotEqual: - v.type = FcTypeBool; - v.u.b = vl.u.d != vr.u.d; - break; - case FcOpLess: - v.type = FcTypeBool; - v.u.b = vl.u.d < vr.u.d; - break; - case FcOpLessEqual: - v.type = FcTypeBool; - v.u.b = vl.u.d <= vr.u.d; - break; - case FcOpMore: - v.type = FcTypeBool; - v.u.b = vl.u.d > vr.u.d; - break; - case FcOpMoreEqual: - v.type = FcTypeBool; - v.u.b = vl.u.d >= vr.u.d; - break; default: v.type = FcTypeVoid; break; @@ -742,15 +740,6 @@ FcConfigEvaluate (FcPattern *p, FcExpr *e) v.type = FcTypeBool; v.u.b = vl.u.b && vr.u.b; break; - case FcOpEqual: - case FcOpContains: - v.type = FcTypeBool; - v.u.b = vl.u.b == vr.u.b; - break; - case FcOpNotEqual: - v.type = FcTypeBool; - v.u.b = vl.u.b != vr.u.b; - break; default: v.type = FcTypeVoid; break; @@ -758,15 +747,6 @@ FcConfigEvaluate (FcPattern *p, FcExpr *e) break; case FcTypeString: switch (e->op) { - case FcOpEqual: - case FcOpContains: - v.type = FcTypeBool; - v.u.b = FcStrCmpIgnoreCase (vl.u.s, vr.u.s) == 0; - break; - case FcOpNotEqual: - v.type = FcTypeBool; - v.u.b = FcStrCmpIgnoreCase (vl.u.s, vr.u.s) != 0; - break; case FcOpPlus: v.type = FcTypeString; v.u.s = FcStrPlus (vl.u.s, vr.u.s); @@ -780,15 +760,6 @@ FcConfigEvaluate (FcPattern *p, FcExpr *e) break; case FcTypeMatrix: switch (e->op) { - case FcOpEqual: - case FcOpContains: - v.type = FcTypeBool; - v.u.b = FcMatrixEqual (vl.u.m, vr.u.m); - break; - case FcOpNotEqual: - v.type = FcTypeBool; - v.u.b = FcMatrixEqual (vl.u.m, vr.u.m); - break; case FcOpTimes: v.type = FcTypeMatrix; m = malloc (sizeof (FcMatrix)); @@ -808,26 +779,6 @@ FcConfigEvaluate (FcPattern *p, FcExpr *e) break; } break; - case FcTypeCharSet: - switch (e->op) { - case FcOpContains: - /* vl contains vr if vr is a subset of vl */ - v.type = FcTypeBool; - v.u.b = FcCharSetIsSubset (vr.u.c, vl.u.c); - break; - case FcOpEqual: - v.type = FcTypeBool; - v.u.b = FcCharSetEqual (vl.u.c, vr.u.c); - break; - case FcOpNotEqual: - v.type = FcTypeBool; - v.u.b = !FcCharSetEqual (vl.u.c, vr.u.c); - break; - default: - v.type = FcTypeVoid; - break; - } - break; default: v.type = FcTypeVoid; break; @@ -1068,6 +1019,8 @@ FcConfigSubstitute (FcConfig *config, FcTest *t; FcEdit *e; FcValueList *l; + FcPattern *p_pat = 0; + FcPattern *m; if (!config) { @@ -1089,7 +1042,10 @@ FcConfigSubstitute (FcConfig *config, if (kind == FcMatchPattern) s = config->substPattern; else + { s = config->substFont; + (void) FcPatternGetPattern (p, FC_PATTERN, 0, &p_pat); + } for (; s; s = s->next) { /* @@ -1103,7 +1059,15 @@ FcConfigSubstitute (FcConfig *config, printf ("FcConfigSubstitute test "); FcTestPrint (t); } - st[i].elt = FcPatternFindElt (p, t->field); + st[i].elt = 0; + if (kind == FcMatchFont && t->kind == FcMatchPattern) + m = p_pat; + else + m = p; + if (m) + st[i].elt = FcPatternFindElt (m, t->field); + else + st[i].elt = 0; /* * If there's no such field in the font, * then FcQualAll matches while FcQualAny does not @@ -1122,7 +1086,7 @@ FcConfigSubstitute (FcConfig *config, * Check to see if there is a match, mark the location * to apply match-relative edits */ - st[i].value = FcConfigMatchValueList (p, t, st[i].elt->values); + st[i].value = FcConfigMatchValueList (m, t, st[i].elt->values); if (!st[i].value) break; if (t->qual == FcQualFirst && st[i].value != st[i].elt->values) @@ -1148,11 +1112,17 @@ FcConfigSubstitute (FcConfig *config, */ l = FcConfigValues (p, e->expr, e->binding); /* - * Locate any test associated with this field + * Locate any test associated with this field, skipping + * tests associated with the pattern when substituting in + * the font */ for (t = s->test, i = 0; t; t = t->next, i++) - if (!FcStrCmpIgnoreCase ((FcChar8 *) t->field, (FcChar8 *) e->field)) + { + if ((t->kind == FcMatchFont || kind == FcMatchPattern) && + !FcStrCmpIgnoreCase ((FcChar8 *) t->field, + (FcChar8 *) e->field)) break; + } switch (e->op) { case FcOpAssign: /* diff --git a/src/fcdbg.c b/src/fcdbg.c index d7c22bc3..9f7cec9b 100644 --- a/src/fcdbg.c +++ b/src/fcdbg.c @@ -27,7 +27,7 @@ #include "fcint.h" void -FcValuePrint (FcValue v) +FcValuePrint (const FcValue v) { switch (v.type) { case FcTypeVoid: @@ -54,18 +54,23 @@ FcValuePrint (FcValue v) case FcTypeFTFace: printf (" face"); break; + case FcTypePattern: + printf (" pattern {"); + FcPatternPrint (v.u.p); + printf (" } "); + break; } } void -FcValueListPrint (FcValueList *l) +FcValueListPrint (const FcValueList *l) { for (; l; l = l->next) FcValuePrint (l->value); } void -FcPatternPrint (FcPattern *p) +FcPatternPrint (const FcPattern *p) { int i; FcPatternElt *e; @@ -126,7 +131,7 @@ FcOpPrint (FcOp op) } void -FcExprPrint (FcExpr *expr) +FcExprPrint (const FcExpr *expr) { switch (expr->op) { case FcOpInteger: printf ("%d", expr->u.ival); break; @@ -206,8 +211,16 @@ FcExprPrint (FcExpr *expr) } void -FcTestPrint (FcTest *test) +FcTestPrint (const FcTest *test) { + switch (test->kind) { + case FcMatchPattern: + printf ("pattern "); + break; + case FcMatchFont: + printf ("font "); + break; + } switch (test->qual) { case FcQualAny: printf ("any "); @@ -230,7 +243,7 @@ FcTestPrint (FcTest *test) } void -FcEditPrint (FcEdit *edit) +FcEditPrint (const FcEdit *edit) { printf ("Edit %s ", edit->field); FcOpPrint (edit->op); @@ -239,7 +252,7 @@ FcEditPrint (FcEdit *edit) } void -FcSubstPrint (FcSubst *subst) +FcSubstPrint (const FcSubst *subst) { FcEdit *e; FcTest *t; @@ -261,7 +274,7 @@ FcSubstPrint (FcSubst *subst) } void -FcFontSetPrint (FcFontSet *s) +FcFontSetPrint (const FcFontSet *s) { int i; diff --git a/src/fcint.h b/src/fcint.h index 98228e81..b861dc1c 100644 --- a/src/fcint.h +++ b/src/fcint.h @@ -138,8 +138,11 @@ typedef enum _FcQual { FcQualAny, FcQualAll, FcQualFirst, FcQualNotFirst } FcQual; +#define FcMatchDefault ((FcMatchKind) -1) + typedef struct _FcTest { struct _FcTest *next; + FcMatchKind kind; FcQual qual; const char *field; FcOp op; @@ -429,22 +432,22 @@ FcFreeTypeGetPrivateMap (FT_Encoding encoding); /* fcdbg.c */ void -FcValueListPrint (FcValueList *l); +FcValueListPrint (const FcValueList *l); void FcOpPrint (FcOp op); void -FcTestPrint (FcTest *test); +FcTestPrint (const FcTest *test); void -FcExprPrint (FcExpr *expr); +FcExprPrint (const FcExpr *expr); void -FcEditPrint (FcEdit *edit); +FcEditPrint (const FcEdit *edit); void -FcSubstPrint (FcSubst *subst); +FcSubstPrint (const FcSubst *subst); int FcDebug (void); @@ -477,7 +480,11 @@ char * FcConfigSaveField (const char *field); FcTest * -FcTestCreate (FcQual qual, const FcChar8 *field, FcOp compare, FcExpr *expr); +FcTestCreate (FcMatchKind kind, + FcQual qual, + const FcChar8 *field, + FcOp compare, + FcExpr *expr); void FcTestDestroy (FcTest *test); diff --git a/src/fclist.c b/src/fclist.c index b87e92f5..e57f2bde 100644 --- a/src/fclist.c +++ b/src/fclist.c @@ -1,5 +1,5 @@ /* - * $XFree86: xc/lib/fontconfig/src/fclist.c,v 1.5 2002/06/03 08:31:15 keithp Exp $ + * $XFree86: xc/lib/fontconfig/src/fclist.c,v 1.7 2002/06/19 20:08:22 keithp Exp $ * * Copyright © 2000 Keith Packard, member of The XFree86 Project, Inc. * @@ -247,6 +247,8 @@ FcListValueHash (FcValue v) return FcCharSetCount (v.u.c); case FcTypeFTFace: return (FcChar32) v.u.f; + case FcTypePattern: + return (FcChar32) v.u.p->num; } return 0; } diff --git a/src/fcmatch.c b/src/fcmatch.c index 02b739c6..99e9fd1b 100644 --- a/src/fcmatch.c +++ b/src/fcmatch.c @@ -1,5 +1,5 @@ /* - * $XFree86: xc/lib/fontconfig/src/fcmatch.c,v 1.15 2002/06/29 20:31:02 keithp Exp $ + * $XFree86: xc/lib/fontconfig/src/fcmatch.c,v 1.16 2002/07/06 23:47:44 keithp Exp $ * * Copyright © 2000 Keith Packard, member of The XFree86 Project, Inc. * @@ -384,26 +384,12 @@ FcFontRenderPrepare (FcConfig *config, pe = FcPatternFindElt (pat, fe->object); if (pe) { - int j; - double score[NUM_MATCH_VALUES]; - - for (j = 0; j < NUM_MATCH_VALUES; j++) - score[j] = 0; if (!FcCompareValueList (pe->object, pe->values, - fe->values, &v, score, &result)) + fe->values, &v, 0, &result)) { FcPatternDestroy (new); return 0; } - for (j = 0; j < NUM_MATCH_VALUES; j++) - if (score[j] >= 100.0) - { - FcValueList *pv; - - for (pv = pe->values; pv; pv = pv->next) - FcPatternAdd (new, fe->object, pv->value, FcTrue); - break; - } } else v = fe->values->value; @@ -416,6 +402,7 @@ FcFontRenderPrepare (FcConfig *config, if (!fe) FcPatternAdd (new, pe->object, pe->values->value, FcTrue); } + FcPatternAddPattern (new, FC_PATTERN, pat); FcConfigSubstitute (config, new, FcMatchFont); return new; } diff --git a/src/fcname.c b/src/fcname.c index e6c07580..fc8c3a41 100644 --- a/src/fcname.c +++ b/src/fcname.c @@ -1,5 +1,5 @@ /* - * $XFree86: xc/lib/fontconfig/src/fcname.c,v 1.9 2002/06/26 22:14:08 keithp Exp $ + * $XFree86: xc/lib/fontconfig/src/fcname.c,v 1.10 2002/06/29 20:31:02 keithp Exp $ * * Copyright © 2000 Keith Packard, member of The XFree86 Project, Inc. * @@ -472,6 +472,8 @@ FcNameUnparseValue (FcStrBuf *buf, return FcNameUnparseCharSet (buf, v.u.c); case FcTypeFTFace: return FcTrue; + case FcTypePattern: + return FcTrue; } return FcFalse; } diff --git a/src/fcpat.c b/src/fcpat.c index 62d779ba..a12414b2 100644 --- a/src/fcpat.c +++ b/src/fcpat.c @@ -1,5 +1,5 @@ /* - * $XFree86: xc/lib/fontconfig/src/fcpat.c,v 1.11 2002/07/06 23:47:44 keithp Exp $ + * $XFree86: xc/lib/fontconfig/src/fcpat.c,v 1.12 2002/08/07 01:45:59 keithp Exp $ * * Copyright © 2000 Keith Packard, member of The XFree86 Project, Inc. * @@ -55,6 +55,9 @@ FcValueDestroy (FcValue v) case FcTypeCharSet: FcCharSetDestroy ((FcCharSet *) v.u.c); break; + case FcTypePattern: + FcPatternDestroy ((FcPattern *) v.u.p); + break; default: break; } @@ -79,6 +82,9 @@ FcValueSave (FcValue v) if (!v.u.c) v.type = FcTypeVoid; break; + case FcTypePattern: + FcPatternReference ((FcPattern *) v.u.p); + break; default: break; } @@ -101,6 +107,9 @@ FcValueListDestroy (FcValueList *l) case FcTypeCharSet: FcCharSetDestroy ((FcCharSet *) l->value.u.c); break; + case FcTypePattern: + FcPatternDestroy ((FcPattern *) l->value.u.p); + break; default: break; } @@ -145,6 +154,8 @@ FcValueEqual (FcValue va, FcValue vb) return FcCharSetEqual (va.u.c, vb.u.c); case FcTypeFTFace: return va.u.f == vb.u.f; + case FcTypePattern: + return FcPatternEqual (va.u.p, vb.u.p); } return FcFalse; } @@ -195,6 +206,8 @@ FcValueHash (FcValue v) case FcTypeFTFace: return FcStringHash ((const FcChar8 *) ((FT_Face) v.u.f)->family_name) ^ FcStringHash ((const FcChar8 *) ((FT_Face) v.u.f)->style_name); + case FcTypePattern: + return (FcChar32) v.u.p->num; } return FcFalse; } @@ -446,6 +459,9 @@ bail2: case FcTypeCharSet: FcCharSetDestroy ((FcCharSet *) value.u.c); break; + case FcTypePattern: + FcPatternDestroy ((FcPattern *) value.u.p); + break; default: break; } @@ -563,6 +579,16 @@ FcPatternAddFTFace (FcPattern *p, const char *object, const FT_Face f) return FcPatternAdd (p, object, v, FcTrue); } +FcBool +FcPatternAddPattern (FcPattern *p, const char *object, const FcPattern *pp) +{ + FcValue v; + + v.type = FcTypePattern; + v.u.p = pp; + return FcPatternAdd (p, object, v, FcTrue); +} + FcResult FcPatternGet (FcPattern *p, const char *object, int id, FcValue *v) { @@ -704,6 +730,21 @@ FcPatternGetFTFace (FcPattern *p, const char *object, int id, FT_Face *f) return FcResultMatch; } +FcResult +FcPatternGetPattern (FcPattern *p, const char *object, int id, FcPattern **pp) +{ + FcValue v; + FcResult r; + + r = FcPatternGet (p, object, id, &v); + if (r != FcResultMatch) + return r; + if (v.type != FcTypePattern) + return FcResultTypeMismatch; + *pp = (FcPattern *) v.u.p; + return FcResultMatch; +} + FcPattern * FcPatternDuplicate (FcPattern *orig) { diff --git a/src/fcxml.c b/src/fcxml.c index 5fea07cf..e265fa53 100644 --- a/src/fcxml.c +++ b/src/fcxml.c @@ -1,5 +1,5 @@ /* - * $XFree86: xc/lib/fontconfig/src/fcxml.c,v 1.16 2002/07/12 19:19:16 keithp Exp $ + * $XFree86: xc/lib/fontconfig/src/fcxml.c,v 1.17 2002/07/31 01:36:37 keithp Exp $ * * Copyright © 2002 Keith Packard, member of The XFree86 Project, Inc. * @@ -49,13 +49,18 @@ #endif FcTest * -FcTestCreate (FcQual qual, const FcChar8 *field, FcOp compare, FcExpr *expr) +FcTestCreate (FcMatchKind kind, + FcQual qual, + const FcChar8 *field, + FcOp compare, + FcExpr *expr) { FcTest *test = (FcTest *) malloc (sizeof (FcTest)); if (test) { test->next = 0; + test->kind = kind; test->qual = qual; test->field = (char *) FcStrCopy (field); test->op = compare; @@ -1204,7 +1209,8 @@ FcParseAlias (FcConfigParse *parse) } if (edit) { - test = FcTestCreate (FcQualAny, + test = FcTestCreate (FcMatchPattern, + FcQualAny, (FcChar8 *) FC_FAMILY, FcOpEqual, family); @@ -1358,6 +1364,8 @@ FcConfigLexCompare (const FcChar8 *compare) static void FcParseTest (FcConfigParse *parse) { + const FcChar8 *kind_string; + FcMatchKind kind; const FcChar8 *qual_string; FcQual qual; const FcChar8 *name; @@ -1366,6 +1374,23 @@ FcParseTest (FcConfigParse *parse) FcExpr *expr; FcTest *test; + kind_string = FcConfigGetAttribute (parse, "target"); + if (!kind_string) + kind = FcMatchDefault; + else + { + if (!strcmp ((char *) kind_string, "pattern")) + kind = FcMatchPattern; + else if (!strcmp ((char *) kind_string, "font")) + kind = FcMatchFont; + else if (!strcmp ((char *) kind_string, "default")) + kind = FcMatchDefault; + else + { + FcConfigMessage (parse, FcSevereWarning, "invalid test target \"%s\"", kind_string); + return; + } + } qual_string = FcConfigGetAttribute (parse, "qual"); if (!qual_string) qual = FcQualAny; @@ -1409,7 +1434,7 @@ FcParseTest (FcConfigParse *parse) FcConfigMessage (parse, FcSevereWarning, "missing test expression"); return; } - test = FcTestCreate (qual, name, compare, expr); + test = FcTestCreate (kind, qual, name, compare, expr); if (!test) { FcConfigMessage (parse, FcSevereError, "out of memory"); diff --git a/src/fontconfig.man b/src/fontconfig.man index 3496f9cb..aedb7141 100644 --- a/src/fontconfig.man +++ b/src/fontconfig.man @@ -1,5 +1,5 @@ .\" -.\" $XFree86: fontconfig.man,v 1.2 2000/11/30 06:59:45 keithp Exp $ +.\" $XFree86: xc/lib/fontconfig/src/fontconfig.man,v 1.2 2002/08/06 19:54:10 keithp Exp $ .\" .\" Copyright © 2002 Keith Packard, member of The XFree86 Project, Inc. .\" @@ -166,6 +166,22 @@ first is to modify how fonts are selected; aliasing families and adding suitable defaults. The second is to modify how the selected fonts are rasterized. Those must apply to the selected font, not the original pattern as false matches will often occur. +.SS FONT LIST MATCHING +.P +While many applications want to locate a single font best matching their +search criteria, other applications need to build a set of fonts which can +be used to present any Unicode data. Fontconfig provides an API to generate +a list sorted by the nearness of each font to the pattern. Every font in +the system is considered, the best matching fonts are placed first. The +application then can select whether the remaining fonts are unconditionally +included in the list, or whether they are included only if they cover +portions of Unicode not covered by any of the preceeding fonts. +.P +The list resulting from this match is represented by references to the +original font patterns and so consumes very little memory. Using a list +entry involves creating a pattern which combines the information from the +font with the information from the original pattern and executing the font +substitutions. .SS FONT NAMES Fontconfig provides a textual representation for patterns that the library can both accept and generate. The representation is in three parts, first a @@ -200,8 +216,8 @@ by the ISO 3166 country code. The hyphen and country code may be elided. .P Fontconfig has orthographies for several languages built into the library. No provision has been made for adding new ones aside from rebuilding the -library. It currently supports 104 of the 139 languages named in ISO 639-1, -117 of the languages with two-letter codes from ISO 639-2 and another 24 +library. It currently supports 122 of the 139 languages named in ISO 639-1, +141 of the languages with two-letter codes from ISO 639-2 and another 30 languages with only three-letter codes. .SH DATATYPES @@ -296,6 +312,15 @@ patterns in the 'fonts' array; 'sfont' is used to indicate the size of that array. .TP +.B FcStrSet +.B FcStrList +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. + +.TP .B FcObjectSet .sp .nf @@ -305,10 +330,35 @@ array. const char **objects; } FcObjectSet; .fi +.sp 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. .TP +.B FcObjectType +.sp + typedef struct _FcObjectType { + const char *object; + FcType type; + } FcObjectType; +.fi +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. + +.TP +.B FcConstant +.sp + typedef struct _FcConstant { + const FcChar8 *name; + const char *object; + int value; + } FcConstant; +.fi +Provides for symbolic constants for new pattern elements. When 'name' is +seen in a font name, an 'object' element is created with value 'value'. + +.TP .B FcBlanks 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 @@ -357,6 +407,11 @@ Used as a return type for functions manipulating FcPattern objects. .br .DT +.TP +.B FcAtomic +Used for locking access to config files. Provides a safe way to update +configuration files. + .SH FUNCTIONS .SS FcMatrix @@ -450,6 +505,18 @@ Returns the number of chars that are in both 'a' and 'b'. FcChar32 FcCharSetSubtractCount (const FcCharSet *a, const FcCharSet *b) Returns the number of chars that are in 'a' but not in 'b'. +.TP +FcBool FcCharSetIsSubset (const FcCharSet *a, const FcCharSet *b) +Returns whether 'a' is a subset of 'b'. + +.TP FcChar32 FcCharSetFirstPage (const FcCharSet *a, FcChar32 [FC_CHARSET_MAP_SIZE], FcChar32 *next) +Builds an array of bits marking the first page of Unicode coverage of 'a'. +Returns the base of the array. 'next' contains the next page in the font. + +.TP FcChar32 FcCharSetNextPage (const FcCharSet *a, FcChar32 [FC_CHARSET_MAP_SIZE], FcChar32 *next) +Builds an array of bits marking the Unicode coverage of 'a' for page '*next'. +Returns the base of the array. 'next' contains the next page in the font. + .SS FcValue FcValue is a structure containing a type tag and a union of all possible datatypes. The tag is an enum of type @@ -480,6 +547,20 @@ void FcPatternDestroy (FcPattern *p) Destroys a pattern, in the process destroying all related values. .TP +FcBool FcPatternEqual (const FcPattern *pa, const FcPattern *pb); +Returns whether 'pa' and 'pb' are exactly alike. + +.TP +FcBool FcPatternEqualSubset (const FcPattern *pa, const FcPattern *pb, const FcObjectSet *os) +Returns whether 'pa' and 'pb' have exactly the same values for all of the +objects in 'os'. + +.TP +FcChar32 FcPatternHash (const FcPattern *p) +Returns a 32-bit number which is the same for any two patterns which are +exactly alike. + +.TP FcBool FcPatternAdd (FcPattern *p, const char *object, FcValue value, FcBool append) Adds a single value to the list of values associated with the property named `object'. If `append' is FcTrue, the value is added at the end of any @@ -565,7 +646,7 @@ Deletes all values associated with the property `object', returning whether the property existed or not. .TP -void FcPatternPrint (FcPattern *p) +void FcPatternPrint (const FcPattern *p) Prints an easily readable version of the pattern to stdout. There is no provision for reparsing data in this format, it's just for diagnostics and debugging. @@ -635,6 +716,41 @@ FcObjectSet *FcObjectSetBuild (const char *first, ...) FcObjectSet *FcObjectSetVaBuild (const char *first, va_list va) These build an object set from a null-terminated list of property names. +.SS FcObjectType +Provides for applcation-specified font name object types so that new +pattern elements can be generated from font names. + +.TP FcBool FcNameRegisterObjectTypes (const FcObjectType *types, int ntype) +Register 'ntype' new object types. + +.TP +FcBool FcNameUnregisterObjectTypes (const FcObjectType *types, int ntype) +Unregister 'ntype' object types. + +.TP +const FcObjectType *FcNameGetObjectType (const char *object) +Return the object type for the pattern element named 'object'. + +.SS FcConstant +Provides for application-specified symbolic constants for font names. + +.TP +FcBool FcNameRegisterConstants (const FcConstant *consts, int nconsts) +Register 'nconsts' new symbolic constants. + +.TP +FcBool FcNameUnregisterConstants (const FcConstant *consts, int nconsts) +Unregister 'nconsts' symbolic constants. + +.TP +const FcConstant *FcNameGetConstant (FcChar8 *string) +Return the FcConstant structure related to symbolic constant 'string'. + +.TP +FcBool FcNameConstant (FcChar8 *string, int *result); +Returns whether a symbolic constant with name 'string' is registered, +placing the value of the constant in 'result' if present. + .SS FcBlanks 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 @@ -685,17 +801,29 @@ FcConfig *FcConfigGetCurrent (void) Returns the current default configuration. .TP +FcBool FcConfigUptoDate (FcConfig *config) +Checks all of the files related to 'config' and returns whether the +in-memory version is in sync with the disk version. + +.TP FcBool FcConfigBuildFonts (FcConfig *config) Builds the set of available fonts for the given configuration. Note that any changes to the configuration after this call have indeterminate effects. Returns FcFalse if this operation runs out of memory. .TP -char **FcConfigGetDirs (FcConfig *config) -Returns the list of font directories specified in 'config'. +FcStrList *FcConfigGetConfigDirs (FcConfig *config) +Returns the list of font directories specified in the configuration files +for 'config'. Does not include any subdirectories. + +.TP +FcStrList *FcConfigGetFontDirs (FcConfig *config) +Returns the list of font directories in 'config'. This includes the +configured font directories along with any directories below those in the +filesystem. .TP -char **FcConfigGetConfigFiles (FcConfig *config) +FcStrList *FcConfigGetConfigFiles (FcConfig *config) Returns the list of known configuration files used to generate 'config'. Note that this will not include any configuration done with FcConfigParse. @@ -714,6 +842,16 @@ Returns the FcBlanks object associated with the given configuration, if no blanks were present in the configuration, this function will return 0. .TP +int FcConfigGetRescanInverval (FcConfig *config) +Returns the interval between automatic checks of the configuration (in +seconds) specified in 'config'. The configuration is checked during +a call to FcFontList when this interval has passed since the last check. + +.TP +FcBool FcConfigSetRescanInverval (FcConfig *config, int rescanInterval) +Sets the rescan interval; returns FcFalse if an error occurred. + +.TP FcBool FcConfigAppFontAddFile (FcConfig *config, const char *file) Adds an application-specific font to the configuration. @@ -736,7 +874,30 @@ if 'kind' is FcMatchFont, those tagged as font operations are applied. FcPattern *FcFontMatch (FcConfig *config, FcPattern *p, FcResult *result) Returns the font in 'config' most close matching 'p'. This function should be called only after FcConfigSubstitute and FcDefaultSubstitute have -been called; otherwise the results will be less useful. +been called for 'p'; otherwise the results will not be correct. + +.TP +FcFontSet *FcFontSort (FcConfig *config, FcPattern *p, FcBool trim, FcCharSet **csp, FcResult *result) Returns the list of fonts sorted by +closeness to 'p'. If 'trim' is FcTrue, elements in the list which don't +include Unicode coverage not provided by earlier elements in the list are +elided. The union of Unicode coverage of all of the fonts is returned in +'csp', if 'csp' is not NULL. This function should be called only after +FcConfigSubstitute and FcDefaultSubstitute have been called for 'p'; +otherwise the results will not be correct. +.P +The returned FcFontSet references FcPattern structures which may be shared +by the return value from multiple FcFontSort calls, applications must not +modify these patterns. Instead, they should be passed, along with 'p' to +FcFontRenderPrepare which combines them into a complete pattern. +.P +The FcFontSet returned by FcFontSort is destroyed by caling FcFontSetDestroy. + +.TP +FcPattern *FcFontRenderPrepare (FcConfig *config, FcPattern *pat, FcPattern *font) +Creates a new pattern consisting of elements of 'font' not appearing in +'pat', elements of 'pat' not appearing in 'font' and the best matching value +from 'pat' for elements appearing in both. The result is passed to +FcConfigSubstitute with 'kind' FcMatchFont and then returned. .TP FcFontSet *FcFontList (FcConfig *config, FcPattern *p, FcObjectSet *os) @@ -761,18 +922,80 @@ FC_CONFIG_DIR environment variable. These functions provide some control over how the library is initialized. .TP -FcBool FcInitConfig (void) -Initializes the default configuration using the default configuration file +FcConfig *FcInitLoadConfig (void) +Loads the default configuration file and returns the resulting configuration. +Does not load any font information. .TP -FcBool FcInitFonts (void) -Initializes the set of fonts available in the default configuration +FcConfig *FcInitLoadConfigAndFonts (void) +Loads the default configuration file and builds information about the +available fonts. Returns the resulting configuration. .TP FcBool FcInit (void) -Calls FcInitConfig and FcInitFonts to completely initialize the default +Loads the default configuration file and the fonts referenced therein and +sets the default configuration to that result. Returns whether this +process succeeded or not. If the default configuration has already +been loaded, this routine does nothing and returns FcTrue. + +.TP +int FcGetVersion (void) +Returns the version number of the library. + +.TP +FcBool FcInitReinitialize (void) +Forces the default configuration file to be reloaded and resets the default configuration. +.TP +FcBool FcInitBringUptoDate (void) +Checks the rescan interval in the default configuration, checking the +configuration if the interval has passed and reloading the configuration if +when any changes are detected. + +.SS FcAtomic +These functions provide a safe way to update config files, allowing ongoing +reading of the old config file while locked for writing and ensuring that a +consistent and complete version of the config file is always available. + +.TP +FcAtomic * FcAtomicCreate (const FcChar8 *file) +Creates a data structure containing data needed to control access to 'file'. +Writing is done to a separate file. Once that file is complete, the original +configuration file is atomically replaced so that reading process always see +a consistent and complete file without the need to lock for reading. + +.TP +FcBool FcAtomicLock (FcAtomic *atomic) +Attempts to lock the file referenced by 'atomic'. Returns FcFalse if the +file is locked by another process, else returns FcTrue and leaves the file +locked. + +.TP +FcChar8 *FcAtomicNewFile (FcAtomic *atomic) +Returns the filename for writing a new version of the file refernced by +'atomic'. + +.TP +FcChar8 *FcAtomicOrigFile (FcAtomic *atomic) +Returns the file refernced by 'atomic'. + +.TP +FcBool FcAtomicReplaceOrig (FcAtomic *atomic) +Replaces the original file referenced by 'atomic' with the new file. + +.TP +void FcAtomicDeleteNew (FcAtomic *atomic) +Deletes the new file. + +.TP +void FcAtomicUnlock (FcAtomic *atomic) +Unlocks the file. + +.TP +void FcAtomicDestroy (FcAtomic *atomic) +Destroys 'atomic'. + .SS FreeType specific functions .nf .B #include <fontconfig/fcfreetype.h> @@ -814,28 +1037,78 @@ FcConfigFilename. This doesn't load a complete configuration as any include files referenced from 'file' will not be loaded. .TP -FcBool FcConfigParse (FcConfig *config, xmlDocPtr doc) -Walks the given configuration and constructs the internal representation in -'config'. Any include files referenced from within 'doc' will be loaded -with FcConfigLoad and also parsed. +FcBool FcConfigParseAndLoad (FcConfig *config, const FcChar8 *file, FcBool complain) +Walks the configuration in 'file' and constructs the internal representation in +'config'. Any include files referenced from within 'file' will be loaded +with FcConfigLoad and also parsed. If 'complain' is FcFalse, no warning +will be displayed if 'file' does not exist. .SS File and Directory routines .TP -FcBool FcFileScan (FcFontSet *set, FcFileCache *cache, FcBlanks *blanks, const char *file, FcBool force) +FcBool FcFileScan (FcFontSet *set, FcStrSet *dirs, FcFileCache *cache, FcBlanks *blanks, const char *file, FcBool force) Scans a single file and adds all fonts found to 'set'. If 'force' is FcTrue, then the file is scanned even if associated information is found in 'cache'. +If 'file' is a directory, it is added to 'dirs'. .TP -FcBool FcDirScan (FcFontSet *set, FcFileCache *cache, FcBlanks *blanks, const char *dir, FcBool force) +FcBool FcDirScan (FcFontSet *set, FcStrSet *dirs, FcFileCache *cache, FcBlanks *blanks, const char *dir, FcBool force) Scans an entire directory and adds all fonts found to 'set'. If 'force' is FcTrue, then the directory and all files within it are scanned even if -information is present in the per-directory cache file or 'cache'. +information is present in the per-directory cache file or 'cache'. Any +subdirectories found are added to 'dirs'. .TP -FcBool FcDirSave (FcFontSet *set, const char *dir) +FcBool FcDirSave (FcFontSet *set, FcStrSet *dirs, const char *dir) Creates the per-directory cache file for 'dir' and populates it with the -fonts in 'set'. +fonts in 'set' and subdirectories in 'dirs'. + +.TP +FcBool FcDirCacheValid (const FcChar8 *cache_file) +Returns FcTrue if 'cache_file' is no older than the directory containing it, +else FcFalse. + +.SS FcStrSet and FcStrList +A data structure for enumerating strings, used to list directories while +scanning the configuration as directories are added while scanning. + +.TP +FcStrSet *FcStrSetCreate (void) +Create an empty set. + +.TP +FcBool FcStrSetMember (FcStrSet *set, const FcChar8 *s) +Returns whether 's' is a member of 'set'. + +.TP +FcBool FcStrSetAdd (FcStrSet *set, const FcChar8 *s) +Adds a copy of 's' to 'set'. + +.TP +FcBool FcStrSetAddFilename (FcStrSet *set, const FcChar8 *s) +Adds a copy 's' to 'set', The copy is created with FcStrCopyFilename +so that leading '~' values are replaced with the value of the HOME +environment variable. + +.TP +FcBool FcStrSetDel (FcStrSet *set, const FcChar8 *s) +Removes 's' from 'set', returning FcTrue if 's' was a member else FcFalse. + +.TP +void FcStrSetDestroy (FcStrSet *set) +Destroys 'set'. + +.TP +FcStrList *FcStrListCreate (FcStrSet *set) +Creates an enumerator to list the strings in 'set'. + +.TP +FcChar8 *FcStrListNext (FcStrList *list) +Returns the next string in 'set'. + +.TP +void FcStrListDone (FcStrList *list) +Destroys the enumerator 'list'. .SS String utilities @@ -871,16 +1144,29 @@ bytes needed to hold the largest unicode char counted. The return value indicates whether 'string' is a well-formed UTF16 string. .TP -char *FcStrCopy (const char *s) +FcChar8 *FcStrCopy (const FcChar8 *s) Allocates memory, copies 's' and returns the resulting buffer. Yes, this is 'strdup', but that function isn't available on every platform. .TP +FcChar8 *FcStrCopyFilename (const FcChar8 *s) +Just like FcStrCopy except that it converts any leading '~' characters in +'s' to the value of the HOME environment variable. + +.TP int FcStrCmpIgnoreCase (const char *s1, const char *s2) Returns the usual <0, 0, >0 result of comparing 's1' and 's2'. This test is case-insensitive in the ASCII range and will operate properly with UTF8 encoded strings, although it does not check for well formed strings. +.TP +FcChar8 *FcStrDirname (const FcChar8 *file) +Returns the directory containing 'file'. + +.TP +FcChar8 *FcStrBasename (const FcChar8 *file) +Returns the filename of 'file' stripped of any leading directory names. + .SH CONFIGURATION FILE FORMAT Configuration files for fontconfig are stored in XML format; this format makes external configuration tools easier to write and ensures that |