]> git.wh0rd.org - fontconfig.git/blob - src/fcdbg.c
79e195349a5fb1e8219fafff7193f9b799c704dc
[fontconfig.git] / src / fcdbg.c
1 /*
2 * fontconfig/src/fcdbg.c
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 the author(s) not be used in
11 * advertising or publicity pertaining to distribution of the software without
12 * specific, written prior permission. The authors make 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 * THE AUTHOR(S) DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
17 * INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO
18 * EVENT SHALL THE AUTHOR(S) 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 #include "fcint.h"
26 #include <stdio.h>
27 #include <stdlib.h>
28
29 void
30 FcValuePrint (const FcValue v)
31 {
32 switch (v.type) {
33 case FcTypeVoid:
34 printf (" <void>");
35 break;
36 case FcTypeInteger:
37 printf (" %d(i)", v.u.i);
38 break;
39 case FcTypeDouble:
40 printf (" %g(f)", v.u.d);
41 break;
42 case FcTypeString:
43 printf (" \"%s\"", v.u.s);
44 break;
45 case FcTypeBool:
46 printf (" %s", v.u.b ? "FcTrue" : "FcFalse");
47 break;
48 case FcTypeMatrix:
49 printf (" (%f %f; %f %f)", v.u.m->xx, v.u.m->xy, v.u.m->yx, v.u.m->yy);
50 break;
51 case FcTypeCharSet: /* XXX */
52 printf (" ");
53 FcCharSetPrint (v.u.c);
54 break;
55 case FcTypeLangSet:
56 printf (" ");
57 FcLangSetPrint (v.u.l);
58 break;
59 case FcTypeFTFace:
60 printf (" face");
61 break;
62 }
63 }
64
65 void
66 FcValueListPrint (FcValueListPtr l)
67 {
68 for (; l != NULL; l = FcValueListNext(l))
69 {
70 FcValuePrint (FcValueCanonicalize(&l->value));
71 switch (l->binding) {
72 case FcValueBindingWeak:
73 printf ("(w)");
74 break;
75 case FcValueBindingStrong:
76 printf ("(s)");
77 break;
78 case FcValueBindingSame:
79 printf ("(=)");
80 break;
81 }
82 }
83 }
84
85 void
86 FcLangSetPrint (const FcLangSet *ls)
87 {
88 FcStrBuf buf;
89 FcChar8 init_buf[1024];
90
91 FcStrBufInit (&buf, init_buf, sizeof (init_buf));
92 if (FcNameUnparseLangSet (&buf, ls) && FcStrBufChar (&buf,'\0'))
93 printf ("%s", buf.buf);
94 else
95 printf ("langset (alloc error)");
96 FcStrBufDestroy (&buf);
97 }
98
99 void
100 FcCharSetPrint (const FcCharSet *c)
101 {
102 int i, j;
103 intptr_t *leaves = FcCharSetLeaves (c);
104 FcChar16 *numbers = FcCharSetNumbers (c);
105
106 #if 0
107 printf ("CharSet 0x%x\n", (intptr_t) c);
108 printf ("Leaves: +%d = 0x%x\n", c->leaves_offset, (intptr_t) leaves);
109 printf ("Numbers: +%d = 0x%x\n", c->numbers_offset, (intptr_t) numbers);
110
111 for (i = 0; i < c->num; i++)
112 {
113 printf ("Page %d: %04x +%d = 0x%x\n",
114 i, numbers[i], leaves[i],
115 (intptr_t) FcOffsetToPtr (leaves, leaves[i], FcCharLeaf));
116 }
117 #endif
118
119 printf ("\n");
120 for (i = 0; i < c->num; i++)
121 {
122 intptr_t leaf_offset = leaves[i];
123 FcCharLeaf *leaf = FcOffsetToPtr (leaves, leaf_offset, FcCharLeaf);
124
125 printf ("\t");
126 printf ("%04x:", numbers[i]);
127 for (j = 0; j < 256/32; j++)
128 printf (" %08x", leaf->map[j]);
129 printf ("\n");
130 }
131 }
132
133 void
134 FcPatternPrint (const FcPattern *p)
135 {
136 int i;
137 FcPatternElt *e;
138
139 if (!p)
140 {
141 printf ("Null pattern\n");
142 return;
143 }
144 printf ("Pattern has %d elts (size %d)\n", p->num, p->size);
145 for (i = 0; i < p->num; i++)
146 {
147 e = &FcPatternElts(p)[i];
148 printf ("\t%s:", FcObjectName(e->object));
149 FcValueListPrint (FcPatternEltValues(e));
150 printf ("\n");
151 }
152 printf ("\n");
153 }
154
155 void
156 FcOpPrint (FcOp op)
157 {
158 switch (op) {
159 case FcOpInteger: printf ("Integer"); break;
160 case FcOpDouble: printf ("Double"); break;
161 case FcOpString: printf ("String"); break;
162 case FcOpMatrix: printf ("Matrix"); break;
163 case FcOpRange: printf ("Range"); break;
164 case FcOpBool: printf ("Bool"); break;
165 case FcOpCharSet: printf ("CharSet"); break;
166 case FcOpField: printf ("Field"); break;
167 case FcOpConst: printf ("Const"); break;
168 case FcOpAssign: printf ("Assign"); break;
169 case FcOpAssignReplace: printf ("AssignReplace"); break;
170 case FcOpPrepend: printf ("Prepend"); break;
171 case FcOpPrependFirst: printf ("PrependFirst"); break;
172 case FcOpAppend: printf ("Append"); break;
173 case FcOpAppendLast: printf ("AppendLast"); break;
174 case FcOpQuest: printf ("Quest"); break;
175 case FcOpOr: printf ("Or"); break;
176 case FcOpAnd: printf ("And"); break;
177 case FcOpEqual: printf ("Equal"); break;
178 case FcOpNotEqual: printf ("NotEqual"); break;
179 case FcOpLess: printf ("Less"); break;
180 case FcOpLessEqual: printf ("LessEqual"); break;
181 case FcOpMore: printf ("More"); break;
182 case FcOpMoreEqual: printf ("MoreEqual"); break;
183 case FcOpContains: printf ("Contains"); break;
184 case FcOpNotContains: printf ("NotContains"); break;
185 case FcOpPlus: printf ("Plus"); break;
186 case FcOpMinus: printf ("Minus"); break;
187 case FcOpTimes: printf ("Times"); break;
188 case FcOpDivide: printf ("Divide"); break;
189 case FcOpNot: printf ("Not"); break;
190 case FcOpNil: printf ("Nil"); break;
191 case FcOpComma: printf ("Comma"); break;
192 case FcOpFloor: printf ("Floor"); break;
193 case FcOpCeil: printf ("Ceil"); break;
194 case FcOpRound: printf ("Round"); break;
195 case FcOpTrunc: printf ("Trunc"); break;
196 case FcOpListing: printf ("Listing"); break;
197 case FcOpInvalid: printf ("Invalid"); break;
198 }
199 }
200
201 void
202 FcExprPrint (const FcExpr *expr)
203 {
204 if (!expr) printf ("none");
205 else switch (expr->op) {
206 case FcOpInteger: printf ("%d", expr->u.ival); break;
207 case FcOpDouble: printf ("%g", expr->u.dval); break;
208 case FcOpString: printf ("\"%s\"", expr->u.sval); break;
209 case FcOpMatrix: printf ("[%g %g %g %g]",
210 expr->u.mval->xx,
211 expr->u.mval->xy,
212 expr->u.mval->yx,
213 expr->u.mval->yy); break;
214 case FcOpRange: break;
215 case FcOpBool: printf ("%s", expr->u.bval ? "true" : "false"); break;
216 case FcOpCharSet: printf ("charset\n"); break;
217 case FcOpNil: printf ("nil\n"); break;
218 case FcOpField: printf ("%s", FcObjectName(expr->u.object)); break;
219 case FcOpConst: printf ("%s", expr->u.constant); break;
220 case FcOpQuest:
221 FcExprPrint (expr->u.tree.left);
222 printf (" quest ");
223 FcExprPrint (expr->u.tree.right->u.tree.left);
224 printf (" colon ");
225 FcExprPrint (expr->u.tree.right->u.tree.right);
226 break;
227 case FcOpAssign:
228 case FcOpAssignReplace:
229 case FcOpPrependFirst:
230 case FcOpPrepend:
231 case FcOpAppend:
232 case FcOpAppendLast:
233 case FcOpOr:
234 case FcOpAnd:
235 case FcOpEqual:
236 case FcOpNotEqual:
237 case FcOpLess:
238 case FcOpLessEqual:
239 case FcOpMore:
240 case FcOpMoreEqual:
241 case FcOpContains:
242 case FcOpListing:
243 case FcOpNotContains:
244 case FcOpPlus:
245 case FcOpMinus:
246 case FcOpTimes:
247 case FcOpDivide:
248 case FcOpComma:
249 FcExprPrint (expr->u.tree.left);
250 printf (" ");
251 switch (expr->op) {
252 case FcOpAssign: printf ("Assign"); break;
253 case FcOpAssignReplace: printf ("AssignReplace"); break;
254 case FcOpPrependFirst: printf ("PrependFirst"); break;
255 case FcOpPrepend: printf ("Prepend"); break;
256 case FcOpAppend: printf ("Append"); break;
257 case FcOpAppendLast: printf ("AppendLast"); break;
258 case FcOpOr: printf ("Or"); break;
259 case FcOpAnd: printf ("And"); break;
260 case FcOpEqual: printf ("Equal"); break;
261 case FcOpNotEqual: printf ("NotEqual"); break;
262 case FcOpLess: printf ("Less"); break;
263 case FcOpLessEqual: printf ("LessEqual"); break;
264 case FcOpMore: printf ("More"); break;
265 case FcOpMoreEqual: printf ("MoreEqual"); break;
266 case FcOpContains: printf ("Contains"); break;
267 case FcOpListing: printf ("Listing"); break;
268 case FcOpNotContains: printf ("NotContains"); break;
269 case FcOpPlus: printf ("Plus"); break;
270 case FcOpMinus: printf ("Minus"); break;
271 case FcOpTimes: printf ("Times"); break;
272 case FcOpDivide: printf ("Divide"); break;
273 case FcOpComma: printf ("Comma"); break;
274 default: break;
275 }
276 printf (" ");
277 FcExprPrint (expr->u.tree.right);
278 break;
279 case FcOpNot:
280 printf ("Not ");
281 FcExprPrint (expr->u.tree.left);
282 break;
283 case FcOpFloor:
284 printf ("Floor ");
285 FcExprPrint (expr->u.tree.left);
286 break;
287 case FcOpCeil:
288 printf ("Ceil ");
289 FcExprPrint (expr->u.tree.left);
290 break;
291 case FcOpRound:
292 printf ("Round ");
293 FcExprPrint (expr->u.tree.left);
294 break;
295 case FcOpTrunc:
296 printf ("Trunc ");
297 FcExprPrint (expr->u.tree.left);
298 break;
299 case FcOpInvalid: printf ("Invalid"); break;
300 }
301 }
302
303 void
304 FcTestPrint (const FcTest *test)
305 {
306 switch (test->kind) {
307 case FcMatchPattern:
308 printf ("pattern ");
309 break;
310 case FcMatchFont:
311 printf ("font ");
312 break;
313 case FcMatchScan:
314 printf ("scan ");
315 break;
316 }
317 switch (test->qual) {
318 case FcQualAny:
319 printf ("any ");
320 break;
321 case FcQualAll:
322 printf ("all ");
323 break;
324 case FcQualFirst:
325 printf ("first ");
326 break;
327 case FcQualNotFirst:
328 printf ("not_first ");
329 break;
330 }
331 printf ("%s ", FcObjectName (test->object));
332 FcOpPrint (test->op);
333 printf (" ");
334 FcExprPrint (test->expr);
335 printf ("\n");
336 }
337
338 void
339 FcEditPrint (const FcEdit *edit)
340 {
341 printf ("Edit %s ", FcObjectName (edit->object));
342 FcOpPrint (edit->op);
343 printf (" ");
344 FcExprPrint (edit->expr);
345 }
346
347 void
348 FcSubstPrint (const FcSubst *subst)
349 {
350 FcEdit *e;
351 FcTest *t;
352
353 printf ("match\n");
354 for (t = subst->test; t; t = t->next)
355 {
356 printf ("\t");
357 FcTestPrint (t);
358 }
359 printf ("edit\n");
360 for (e = subst->edit; e; e = e->next)
361 {
362 printf ("\t");
363 FcEditPrint (e);
364 printf (";\n");
365 }
366 printf ("\n");
367 }
368
369 void
370 FcFontSetPrint (const FcFontSet *s)
371 {
372 int i;
373
374 printf ("FontSet %d of %d\n", s->nfont, s->sfont);
375 for (i = 0; i < s->nfont; i++)
376 {
377 printf ("Font %d ", i);
378 FcPatternPrint (s->fonts[i]);
379 }
380 }
381
382 int FcDebugVal;
383
384 void
385 FcInitDebug (void)
386 {
387 char *e;
388
389 e = getenv ("FC_DEBUG");
390 if (e)
391 {
392 printf ("FC_DEBUG=%s\n", e);
393 FcDebugVal = atoi (e);
394 if (FcDebugVal < 0)
395 FcDebugVal = 0;
396 }
397 }
398 #define __fcdbg__
399 #include "fcaliastail.h"
400 #undef __fcdbg__