#include "fitz-base.h"
#include "fitz-world.h"
static void indent(int level)
{
while (level--)
putchar(' ');
}
static void xmlnode(fz_node *node, int level);
static void xmlover(fz_overnode *node, int level)
{
fz_node *child;
indent(level);
printf("\n");
for (child = node->super.first; child; child = child->next)
xmlnode(child, level + 1);
indent(level);
printf("\n");
}
static void xmlmask(fz_masknode *node, int level)
{
fz_node *child;
indent(level);
printf("\n");
for (child = node->super.first; child; child = child->next)
xmlnode(child, level + 1);
indent(level);
printf("\n");
}
static void xmlblend(fz_blendnode *node, int level)
{
fz_node *child;
indent(level);
printf("\n", node->mode);
for (child = node->super.first; child; child = child->next)
xmlnode(child, level + 1);
indent(level);
printf("\n");
}
static void xmltransform(fz_transformnode *node, int level)
{
indent(level);
printf("\n",
node->m.a, node->m.b,
node->m.c, node->m.d,
node->m.e, node->m.f);
xmlnode(node->super.first, level + 1);
indent(level);
printf("\n");
}
static void xmlsolid(fz_solidnode *node, int level)
{
int i;
indent(level);
printf("cs->name, node->a);
for (i = 0; i < node->n; i++)
{
printf("%g", node->samples[i]);
if (i < node->n - 1)
putchar(' ');
}
printf("\" />\n");
}
static void xmllink(fz_linknode *node, int level)
{
indent(level);
printf("\n", node->tree);
}
static void xmlpath(fz_pathnode *node, int level)
{
int i;
indent(level);
if (node->paint == FZ_STROKE)
{
printf("linecap,
node->linejoin,
node->linewidth,
node->miterlimit);
if (node->dash)
{
printf(" phase=\"%g\" array=\"", node->dash->phase);
for (i = 0; i < node->dash->len; i++)
printf("%g ", node->dash->array[i]);
printf("\"");
}
printf(">\n");
}
else
{
printf("\n",
node->paint == FZ_FILL ? "nonzero" : "evenodd");
}
fz_debugpathnode(node, level + 2);
indent(level);
printf("\n");
}
static void xmltext(fz_textnode *node, int level)
{
int i;
indent(level);
printf("\n", node->font->name,
node->trm.a, node->trm.b, node->trm.c, node->trm.d);
for (i = 0; i < node->len; i++)
{
indent(level + 1);
if (node->els[i].cid >= 32 && node->els[i].cid < 128)
printf("\n",
node->els[i].cid, node->els[i].x, node->els[i].y);
else
printf("\" x=\"%g\" y=\"%g\" />\n",
node->els[i].cid, node->els[i].x, node->els[i].y);
}
indent(level);
printf("\n");
}
static void xmlimage(fz_imagenode *node, int level)
{
fz_image *image = node->image;
indent(level);
printf("\n",
image->w, image->h, image->n, image->a);
}
static void xmlshade(fz_shadenode *node, int level)
{
indent(level);
printf("\n");
}
static void xmlnode(fz_node *node, int level)
{
if (!node)
{
indent(level);
printf("\n");
return;
}
switch (node->kind)
{
case FZ_NOVER: xmlover((fz_overnode*)node, level); break;
case FZ_NMASK: xmlmask((fz_masknode*)node, level); break;
case FZ_NBLEND: xmlblend((fz_blendnode*)node, level); break;
case FZ_NTRANSFORM: xmltransform((fz_transformnode*)node, level); break;
case FZ_NCOLOR: xmlsolid((fz_solidnode*)node, level); break;
case FZ_NPATH: xmlpath((fz_pathnode*)node, level); break;
case FZ_NTEXT: xmltext((fz_textnode*)node, level); break;
case FZ_NIMAGE: xmlimage((fz_imagenode*)node, level); break;
case FZ_NSHADE: xmlshade((fz_shadenode*)node, level); break;
case FZ_NLINK: xmllink((fz_linknode*)node, level); break;
}
}
void
fz_debugnode(fz_node *node)
{
xmlnode(node, 0);
}
void
fz_debugtree(fz_tree *tree)
{
printf("\n");
xmlnode(tree->root, 1);
printf("\n");
}