summaryrefslogtreecommitdiff
path: root/fc-lang/fc-lang.c
diff options
context:
space:
mode:
authorPatrick Lam <plam@MIT.EDU>2005-06-28 03:41:02 +0000
committerPatrick Lam <plam@MIT.EDU>2005-06-28 03:41:02 +0000
commitcd2ec1a940888ebcbd323a8000d2fcced41ddf9e (patch)
tree841e371cb0e28b003cdfbab8d109e30d84b2a3db /fc-lang/fc-lang.c
parentf1a42f6b5f9bcd774d09002509b2872c04025c1b (diff)
Add functionality to allow fontconfig data structure serialization.
This patch allows the fundamental fontconfig data structures to be serialized. I've converted everything from FcPattern down to be able to use *Ptr objects, which can be either static or dynamic (using a union which either contains a pointer or an index) and replaced storage of pointers in the heap with the appropriate *Ptr object. I then changed all writes of pointers to the heap with a *CreateDynamic call, which creates a dynamic Ptr object pointing to the same object as before. This way, the fundamental fontconfig semantics should be unchanged; I did not have to change external signatures this way, although I did change some internal signatures. When given a *Ptr object, just run *U to get back to a normal pointer; it gives the right answer regardless of whether we're using static or dynamic storage. I've also implemented a Fc*Serialize call. Calling FcFontSetSerialize converts the dynamic FcFontSets contained in the config object to static FcFontSets and also converts its dependencies (e.g. everything you'd need to write to disk) to static objects. Note that you have to call Fc*PrepareSerialize first; this call will count the number of objects that actually needs to be allocated, so that we can avoid realloc. The Fc*Serialize calls then check the static pointers for nullness, and allocate the buffers if necessary. I've tested the execution of fc-list and fc-match after Fc*Serialize and they appear to work the same way.
Diffstat (limited to 'fc-lang/fc-lang.c')
-rw-r--r--fc-lang/fc-lang.c17
1 files changed, 8 insertions, 9 deletions
diff --git a/fc-lang/fc-lang.c b/fc-lang/fc-lang.c
index e88d75f..a2699a3 100644
--- a/fc-lang/fc-lang.c
+++ b/fc-lang/fc-lang.c
@@ -220,7 +220,7 @@ main (int argc, char **argv)
FILE *f;
int ncountry = 0;
int i = 0;
- FcCharLeaf **leaves, **sleaves;
+ FcCharLeaf **leaves;
int total_leaves = 0;
int l, sl, tl;
int c;
@@ -268,14 +268,13 @@ main (int argc, char **argv)
*/
for (i = 0; sets[i]; i++)
{
- sleaves = sets[i]->leaves;
for (sl = 0; sl < sets[i]->num; sl++)
{
for (l = 0; l < tl; l++)
- if (leaves[l] == sleaves[sl])
+ if (leaves[l] == FcCharSetGetLeaf(sets[i], sl))
break;
if (l == tl)
- leaves[tl++] = sleaves[sl];
+ leaves[tl++] = FcCharSetGetLeaf(sets[i], sl);
}
}
@@ -358,7 +357,7 @@ main (int argc, char **argv)
if (n % 8 == 0)
printf (" ");
for (l = 0; l < tl; l++)
- if (leaves[l] == sets[i]->leaves[n])
+ if (leaves[l] == FcCharSetGetLeaf(sets[i], n))
break;
if (l == tl)
fatal (names[i], 0, "can't find leaf");
@@ -377,7 +376,7 @@ main (int argc, char **argv)
{
if (n % 8 == 0)
printf (" ");
- printf (" 0x%04x,", sets[i]->numbers[n]);
+ printf (" 0x%04x,", FcCharSetGetNumbers(sets[i])[n]);
if (n % 8 == 7)
printf ("\n");
}
@@ -399,9 +398,9 @@ main (int argc, char **argv)
if (j < 0)
j = i;
printf (" { (FcChar8 *) \"%s\",\n"
- " { FC_REF_CONSTANT, %d, "
- "(FcCharLeaf **) leaves_%s, "
- "(FcChar16 *) numbers_%s } },\n",
+ " { FC_REF_CONSTANT, %d, FcStorageDynamic, "
+ "{ { (FcCharLeaf **) leaves_%s, "
+ "(FcChar16 *) numbers_%s } } } },\n",
langs[i],
sets[j]->num, names[j], names[j]);
}