/*
- * $XFree86: xc/lib/fontconfig/src/fclist.c,v 1.3 2002/05/21 17:06:22 keithp Exp $
+ * $XFree86: xc/lib/fontconfig/src/fclist.c,v 1.4 2002/06/02 21:07:56 keithp Exp $
*
* Copyright © 2000 Keith Packard, member of The XFree86 Project, Inc.
*
{
int s;
const char **objects;
+ int high, low, mid, c;
if (os->nobject == os->sobject)
{
os->objects = objects;
os->sobject = s;
}
- os->objects[os->nobject++] = object;
+ high = os->nobject - 1;
+ low = 0;
+ mid = 0;
+ c = 1;
+ while (low <= high)
+ {
+ mid = (low + high) >> 1;
+ c = strcmp (os->objects[mid], object);
+ if (c == 0)
+ return FcTrue;
+ if (c < 0)
+ low = mid + 1;
+ else
+ high = mid - 1;
+ }
+ if (c < 0)
+ mid++;
+ memmove (os->objects + mid + 1, os->objects + mid, os->nobject - mid);
+ os->objects[mid] = object;
+ os->nobject++;
return FcTrue;
}
return FcTrue;
}
-/*
- * FcTrue iff all objects in "p" match "font"
- */
-
static FcBool
-FcListPatternMatchAny (FcPattern *p,
- FcPattern *font)
+FcListPatternEqual (FcPattern *p1,
+ FcPattern *p2,
+ FcObjectSet *os)
{
int i;
- FcPatternElt *e;
+ FcPatternElt *e1, *e2;
- for (i = 0; i < p->num; i++)
+ for (i = 0; i < os->nobject; i++)
{
- e = FcPatternFind (font, p->elts[i].object, FcFalse);
- if (!e)
+ e1 = FcPatternFindElt (p1, os->objects[i]);
+ e2 = FcPatternFindElt (p2, os->objects[i]);
+ if (!e1 && !e2)
+ return FcTrue;
+ if (!e1 || !e2)
return FcFalse;
- if (!FcListValueListMatchAny (p->elts[i].values, e->values))
+ if (!FcListValueListEqual (e1->values, e2->values))
return FcFalse;
}
return FcTrue;
}
+/*
+ * FcTrue iff all objects in "p" match "font"
+ */
+
static FcBool
-FcListPatternEqual (FcPattern *p1,
- FcPattern *p2,
- FcObjectSet *os)
+FcListPatternMatchAny (FcPattern *p,
+ FcPattern *font)
{
int i;
- FcPatternElt *e1, *e2;
+ FcPatternElt *e;
- for (i = 0; i < os->nobject; i++)
+ for (i = 0; i < p->num; i++)
{
- e1 = FcPatternFind (p1, os->objects[i], FcFalse);
- e2 = FcPatternFind (p2, os->objects[i], FcFalse);
- if (!e1 && !e2)
- return FcTrue;
- if (!e1 || !e2)
+ e = FcPatternFindElt (font, p->elts[i].object);
+ if (!e)
return FcFalse;
- if (!FcListValueListEqual (e1->values, e2->values))
+ if (!FcListValueListMatchAny (p->elts[i].values, e->values))
return FcFalse;
}
return FcTrue;
for (n = 0; n < os->nobject; n++)
{
- e = FcPatternFind (font, os->objects[n], FcFalse);
+ e = FcPatternFindElt (font, os->objects[n]);
if (e)
h = h ^ FcListValueListHash (e->values);
}
for (o = 0; o < os->nobject; o++)
{
- e = FcPatternFind (font, os->objects[o], FcFalse);
+ e = FcPatternFindElt (font, os->objects[o]);
if (e)
{
for (v = e->values; v; v = v->next)